Client¶
discord_http.client module¶
- class discord_http.client.Client(*, token: str, application_id: int | None = None, public_key: str | None = None, guild_id: int | None = None, sync: bool = False, api_version: int = 10, loop: ~asyncio.events.AbstractEventLoop | None = None, allowed_mentions: ~discord_http.mentions.AllowedMentions = <discord_http.mentions.AllowedMentions object>, enable_gateway: bool = False, automatic_shards: bool = True, playing_status: PlayingStatus | None = None, chunk_guilds_on_startup: bool = False, guild_ready_timeout: float = 2.0, gateway_cache: GatewayCacheFlags | None = None, intents: Intents | None = None, logging_level: int = 20, call_after_delay: float = 0.1, disable_default_get_path: bool = False, debug_events: bool = False)[source]¶
Bases:
object
- async add_cog(cog: Cog) None [source]¶
Adds a cog to the bot.
- Parameters:
cog (Cog) – The cog to add to the bot.
- add_command(func: Command) Command [source]¶
Adds a command to the bot.
- Parameters:
command (Command) – The command to add to the bot.
- add_global_cmd_check(func: Callable) Callable [source]¶
Add a check that will be run before every command
- Parameters:
func (Callable) – The function to add
- add_group(name: str) SubGroup [source]¶
Used to add a sub-command group
- Parameters:
name (str) – Name of the group
- Returns:
The created group
- Return type:
SubGroup
- add_interaction(func: Interaction) Interaction [source]¶
Adds an interaction to the bot.
- Parameters:
interaction (Interaction) – The interaction to add to the bot.
- add_listener(func: Listener) Listener [source]¶
Adds a listener to the bot.
- Parameters:
func (Listener) – The listener to add to the bot.
- command(name: str | None = None, *, description: str | None = None, guild_ids: list[Snowflake | int] | None = None, guild_install: bool = True, user_install: bool = False)[source]¶
Used to register a command
- Parameters:
name (Optional[str]) – Name of the command, if not provided, it will use the function name
description (Optional[str]) – Description of the command, if not provided, it will use the function docstring
guild_ids (Optional[list[Union[Snowflake, int]]]) – List of guild IDs to register the command in
user_install (bool) – Whether the command can be installed by users or not
guild_install (bool) – Whether the command can be installed by guilds or not
- async create_application_emoji(name: str, *, image: File | bytes) Emoji [source]¶
Creates an emoji for the application.
- Parameters:
name (str) – Name of emoji
image (Union[File, bytes]) – The image data to use for the emoji.
- Returns:
The created emoji object.
- Return type:
Emoji
- async create_guild(name: str, *, icon: File | bytes | None = None, reason: str | None = None) Guild [source]¶
Create a guild
Note that the bot must be in less than 10 guilds to use this endpoint
- Parameters:
name (str) – The name of the guild
icon (Optional[File]) – The icon of the guild
reason (Optional[str]) – The reason for creating the guild
- Returns:
The created guild
- Return type:
Guild
- dispatch(event_name: str, /, *args: Any, **kwargs: Any)[source]¶
Dispatches an event to all listeners of that event.
- Parameters:
event_name (str) – The name of the event to dispatch.
*args (Any) – The arguments to pass to the event.
**kwargs (Any) – The keyword arguments to pass to the event.
- async fetch_application_emojis() list[Emoji] [source]¶
list[Emoji]: Fetches all emojis available to the application.
- async fetch_automod_rule(rule_id: int, guild_id: int) AutoModRule [source]¶
Fetches a automod object
- Parameters:
rule_id (int) – The ID of the automod rule
guild_id (int) – The Guild ID where it comes from
- Returns:
The automod object
- Return type:
AutoModRule
- async fetch_channel(channel_id: int, *, guild_id: int | None = None) BaseChannel [source]¶
Fetches a channel object.
- Parameters:
channel_id (int) – Channel ID to fetch the channel object with.
guild_id (Optional[int]) – Guild ID to fetch the channel object with.
- Returns:
The channel object.
- Return type:
BaseChannel
- async fetch_emoji(emoji_id: int, *, guild_id: int | None = None) Emoji [source]¶
Fetches an emoji object.
- Parameters:
emoji_id (int) – The ID of the emoji in question
guild_id (Optional[int]) – Guild ID of the emoji. If None, it will fetch the emoji from the application
- Returns:
The emoji object
- Return type:
Emoji
- async fetch_entitlement(entitlement_id: int) Entitlements [source]¶
Fetches an entitlement object.
- Parameters:
entitlement_id (int) – Entitlement ID to fetch the entitlement object with.
- Returns:
The entitlement object.
- Return type:
Entitlements
- async fetch_entitlement_list(*, user_id: int | None = None, sku_ids: list[int] | None = None, before: int | None = None, after: int | None = None, limit: int | None = 100, guild_id: int | None = None, exclude_ended: bool = False) AsyncIterator[Entitlements] [source]¶
Fetches a list of entitlement objects with optional filters.
- Parameters:
user_id (Optional[int]) – Show entitlements for a specific user ID.
sku_ids (Optional[list[int]]) – Show entitlements for a specific SKU ID.
before (Optional[int]) – Only show entitlements before this entitlement ID.
after (Optional[int]) – Only show entitlements after this entitlement ID.
limit (int) – Limit the amount of entitlements to fetch. Use None to fetch all entitlements.
guild_id (Optional[int]) – Show entitlements for a specific guild ID.
exclude_ended (bool) – Whether to exclude ended entitlements or not.
- Returns:
The entitlement objects.
- Return type:
AsyncIterator[Entitlements]
- async fetch_guild(guild_id: int) Guild [source]¶
Fetches a guild object.
- Parameters:
guild_id (int) – Guild ID to fetch the guild object with.
- Returns:
The guild object.
- Return type:
Guild
- async fetch_invite(invite_code: str) Invite [source]¶
Fetches an invite object.
- Parameters:
invite_code (str) – Invite code to fetch the invite object with.
- Returns:
The invite object.
- Return type:
Invite
- async fetch_member(user_id: int, guild_id: int) Member [source]¶
Fetches a member object.
- Parameters:
guild_id (int) – Guild ID that the member is in.
user_id (int) – User ID to fetch the member object with.
- Returns:
The member object.
- Return type:
Member
- async fetch_message(message_id: int, channel_id: int, guild_id: int | None = None) Message [source]¶
Fetches a message object.
- Parameters:
message_id (int) – Message ID to fetch the message object with.
channel_id (int) – Channel ID to fetch the message object with.
guild_id (Optional[int]) – Guild ID to fetch the message object from.
- Returns:
The message object
- Return type:
Message
- async fetch_scheduled_event(id: int, guild_id: int) ScheduledEvent [source]¶
Fetches a scheduled event object.
- Parameters:
id (int) – The ID of the scheduled event.
guild_id (int) – The guild ID of the scheduled event.
- Returns:
The scheduled event object.
- Return type:
ScheduledEvent
- async fetch_soundboard_sound(sound_id: int, guild_id: int) SoundboardSound [source]¶
Fetches a soundboard sound object.
- Parameters:
sticker_id (int) – Sound ID to fetch the soundboard sound object with.
guild_id (int) – Guild ID to fetch the soundboard sound object from.
- Returns:
The soundboard sound object.
- Return type:
SoundboardSound
- async fetch_sticker(sticker_id: int, *, guild_id: int | None = None) Sticker [source]¶
Fetches a sticker object.
- Parameters:
sticker_id (int) – Sticker ID to fetch the sticker object with.
- Returns:
The sticker object.
- Return type:
Sticker
- async fetch_user(user_id: int) User [source]¶
Fetches a user object.
- Parameters:
user_id (int) – User ID to fetch the user object with.
- Returns:
The user object.
- Return type:
User
- async fetch_voice_state(member_id: int, guild_id: int | None = None) VoiceState [source]¶
Fetches a voice state object.
- Parameters:
member_id (int) – The ID of the member to fetch the voice state from
guild_id (Optional[int]) – Guild ID to fetch the voice state from
- Returns:
The voice state object.
- Return type:
VoiceState
- async fetch_webhook(webhook_id: int, *, webhook_token: str | None = None) Webhook [source]¶
Fetches a webhook object.
- Parameters:
webhook_id (int) – Webhook ID to fetch the webhook object with.
webhook_token (Optional[str]) – Webhook token to fetch the webhook object with.
- Returns:
The webhook object.
- Return type:
Webhook
- find_interaction(custom_id: str) Interaction | None [source]¶
Finds an interaction by its Custom ID.
- Parameters:
custom_id (str) – The Custom ID to find the interaction with. Will automatically convert to regex matching if some interaction Custom IDs are regex.
- Returns:
The interaction that was found if any.
- Return type:
Optional[Interaction]
- get_channel(channel_id: int | None) BaseChannel | PartialChannel | None [source]¶
Get a channel object from the cache.
- Parameters:
channel_id (int) – The ID of the channel to get.
- Returns:
The channel object with the specified ID, or None if not found.
- Return type:
BaseChannel | PartialChannel | None
- get_guild(guild_id: int) Guild | PartialGuild | None [source]¶
Get a guild object from the cache.
- Parameters:
guild_id (int) – The ID of the guild to get.
- Returns:
The guild object with the specified ID, or None if not found.
- Return type:
Guild | PartialGuild | None
- get_partial_automod_rule(rule_id: int, guild_id: int) PartialAutoModRule [source]¶
Creates a partial automod object
- Parameters:
rule_id (int) – The ID of the automod rule
guild_id (int) – The Guild ID where it comes from
- Returns:
The partial automod object
- Return type:
PartialAutoModRule
- get_partial_channel(channel_id: int, *, guild_id: int | None = None) PartialChannel [source]¶
Creates a partial channel object.
- Parameters:
channel_id (int) – Channel ID to create the partial channel object with.
guild_id (Optional[int]) – Guild ID to create the partial channel object with.
- Returns:
The partial channel object.
- Return type:
PartialChannel
- get_partial_emoji(emoji_id: int, *, guild_id: int | None = None) PartialEmoji [source]¶
Creates a partial emoji object.
- Parameters:
emoji_id (int) – Emoji ID to create the partial emoji object with.
guild_id (Optional[int]) – Guild ID of where the emoji comes from. If None, it will get the emoji from the application.
- Returns:
The partial emoji object.
- Return type:
PartialEmoji
- get_partial_entitlement(entitlement_id: int) PartialEntitlements [source]¶
Creates a partial entitlement object.
- Parameters:
entitlement_id (int) – Entitlement ID to create the partial entitlement object with.
- Returns:
The partial entitlement object.
- Return type:
PartialEntitlements
- get_partial_guild(guild_id: int) PartialGuild [source]¶
Creates a partial guild object.
- Parameters:
guild_id (int) – Guild ID to create the partial guild object with.
- Returns:
The partial guild object.
- Return type:
PartialGuild
- get_partial_invite(invite_code: str, *, channel_id: int | None = None, guild_id: int | None = None) PartialInvite [source]¶
Creates a partial invite object.
- Parameters:
invite_code (str) – Invite code to create the partial invite object with.
- Returns:
The partial invite object.
- Return type:
PartialInvite
- get_partial_member(user_id: int, guild_id: int) PartialMember [source]¶
Creates a partial member object.
- Parameters:
user_id (int) – User ID to create the partial member object with.
guild_id (int) – Guild ID that the member is in.
- Returns:
The partial member object.
- Return type:
PartialMember
- get_partial_message(message_id: int, channel_id: int, guild_id: int | None = None) PartialMessage [source]¶
Creates a partial message object.
- Parameters:
message_id (int) – Message ID to create the partial message object with.
channel_id (int) – Channel ID to create the partial message object with.
guild_id (Optional[int]) – Guild ID to create the partial message object with.
- Returns:
The partial message object.
- Return type:
PartialMessage
- get_partial_role(role_id: int, guild_id: int) PartialRole [source]¶
Creates a partial role object.
- Parameters:
role_id (int) – Role ID to create the partial role object with.
guild_id (int) – Guild ID that the role is in.
- Returns:
The partial role object.
- Return type:
PartialRole
- get_partial_scheduled_event(id: int, guild_id: int) PartialScheduledEvent [source]¶
Creates a partial scheduled event object.
- Parameters:
id (int) – The ID of the scheduled event.
guild_id (int) – The guild ID of the scheduled event.
- Returns:
The partial scheduled event object.
- Return type:
PartialScheduledEvent
- get_partial_sku(sku_id: int) PartialSKU [source]¶
Creates a partial SKU object.
- Returns:
The partial SKU object.
- Return type:
PartialSKU
- get_partial_soundboard_sound(sound_id: int, *, guild_id: int | None = None) PartialSoundboardSound [source]¶
Creates a partial sticker object.
- Parameters:
sticker_id (int) – Sound ID to create the partial soundboard sound object with.
guild_id (Optional[int]) – Guild ID to create the partial soundboard sound object with.
- Returns:
The partial soundboard sound object.
- Return type:
PartialSoundboardSound
- get_partial_sticker(sticker_id: int, *, guild_id: int | None = None) PartialSticker [source]¶
Creates a partial sticker object.
- Parameters:
sticker_id (int) – Sticker ID to create the partial sticker object with.
guild_id (Optional[int]) – Guild ID to create the partial sticker object with.
- Returns:
The partial sticker object.
- Return type:
PartialSticker
- get_partial_user(user_id: int) PartialUser [source]¶
Creates a partial user object.
- Parameters:
user_id (int) – User ID to create the partial user object with.
- Returns:
The partial user object.
- Return type:
PartialUser
- get_partial_voice_state(member_id: int, *, guild_id: int | None = None, channel_id: int | None = None) PartialVoiceState [source]¶
Creates a partial voice state object.
- Parameters:
member_id (int) – The ID of the member to create the partial voice state from
guild_id (Optional[int]) – Guild ID to create the partial voice state from
- Returns:
The partial voice state object.
- Return type:
PartialVoiceState
- get_partial_webhook(webhook_id: int, *, webhook_token: str | None = None) PartialWebhook [source]¶
Creates a partial webhook object.
- Parameters:
webhook_id (int) – Webhook ID to create the partial webhook object with.
webhook_token (Optional[str]) – Webhook token to create the partial webhook object with.
- Returns:
The partial webhook object.
- Return type:
PartialWebhook
- get_shard_by_guild_id(guild_id: Snowflake | int) int | None [source]¶
Returns the shard ID of the shard that the guild is in
- Parameters:
guild_id (Snowflake | int) – The ID of the guild to get the shard ID of
- Returns:
The shard ID of the guild, or None if not found
- Return type:
int | None
- Raises:
NotImplementedError – If the gateway is not available
- group(name: str | None = None, *, description: str | None = None)[source]¶
Used to register a sub-command group
- Parameters:
name (Optional[str]) – Name of the group, if not provided, it will use the function name
description (Optional[str]) – Description of the group, if not provided, it will use the function docstring
- property guilds: list[Guild | PartialGuild]¶
Returns a list of all the guilds the bot is in. Only useable if you are using gateway and caching
- Type:
list[Guild]
- has_any_dispatch(event_name: str) bool [source]¶
Checks if the bot has any listeners for the event.
- Parameters:
event_name (str) – The name of the event to check for.
- Returns:
Whether the bot has any listeners for the event.
- Return type:
bool
- interaction(custom_id: str, *, regex: bool = False)[source]¶
Used to register an interaction
This does support regex, so you can use r”regex here” as the custom_id
- Parameters:
custom_id (str) – Custom ID of the interaction
regex (bool) – Whether the custom_id is a regex or not
- listener(name: str | None = None)[source]¶
Used to register a listener
- Parameters:
name (Optional[str]) – Name of the listener, if not provided, it will use the function name
- Raises:
TypeError –
If the listener name is not a string - If the listener is not a coroutine function
- async load_extension(package: str) None [source]¶
Loads an extension.
- Parameters:
package (str) – The package to load the extension from.
- message_command(name: str | None = None, *, guild_ids: list[Snowflake | int] | None = None, guild_install: bool = True, user_install: bool = False)[source]¶
Used to register a message command
Example usage
@message_command() async def content(ctx, msg: Message): await ctx.send(f"Content: {msg.content}")
- Parameters:
name (Optional[str]) – Name of the command, if not provided, it will use the function name
guild_ids (Optional[list[Union[Snowflake, int]]]) – List of guild IDs to register the command in
user_install (bool) – Whether the command can be installed by users or not
guild_install (bool) – Whether the command can be installed by guilds or not
- async query_members(guild_id: Snowflake | int, *, query: str | None = None, limit: int = 0, presences: bool = False, user_ids: list[Snowflake | int] | None = None, shard_id: int | None = None) list[Member] [source]¶
Query members in a guild
- Parameters:
guild_id (Snowflake | int) – The ID of the guild to query members in
query (str | None) – The query to search for
limit (int) – The maximum amount of members to return
presences (bool) – Whether to include presences in the response
user_ids (list[Snowflake | int] | None) – The user IDs to fetch members for
shard_id (int | None) – The shard ID to query the members from
- Returns:
The members that matched the query
- Return type:
list[Member]
- Raises:
ValueError –
If shard_id is not provided - If shard_id is not valid
- async remove_cog(cog: Cog) None [source]¶
Removes a cog from the bot.
- Parameters:
cog (Cog) – The cog to remove from the bot.
- remove_command(func: Command) None [source]¶
Removes a command from the bot.
- Parameters:
command (Command) – The command to remove from the bot.
- remove_interaction(func: Interaction) None [source]¶
Removes an interaction from the bot.
- Parameters:
interaction (Interaction) – The interaction to remove from the bot.
- remove_listener(func: Listener) None [source]¶
Removes a listener from the bot.
- Parameters:
func (Listener) – The listener to remove from the bot.
- set_backend(*, cls: Callable | None = None) None [source]¶
Set the backend to use for the bot
Example of making one:
from discord_http import DiscordHTTP class CustomBackend(DiscordHTTP): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) Client.set_backend(cls=CustomBackend)
- Parameters:
cls (Optional[Callable]) – The backend to use for everything. Leave empty to use the default backend.
- set_context(*, cls: Callable | None = None) None [source]¶
Get the context for a command, while allowing custom context as well
Example of making one:
from discord_http import Context class CustomContext(Context): def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) Client.set_context(cls=CustomContext)
- Parameters:
cls (Optional[Callable]) – The context to use for commands. Leave empty to use the default context.
- async setup_hook() None [source]¶
This will be running after the bot is ready, to get variables set up You can overwrite this function to do your own setup
Example:
async def setup_hook(self) -> None: # Making database connection available through the bot self.pool = SQLite.Database()
- start(*, host: str = '127.0.0.1', port: int = 8080) None [source]¶
Boot up the bot and start the HTTP server
- Parameters:
host (Optional[
str
]) – Host to use, if not provided, it will use 127.0.0.1port (Optional[
int
]) – Port to use, if not provided, it will use 8080
- async sync_commands() None [source]¶
Make the bot fetch all current commands, to then sync them all to Discord API.
- async unload_extension(package: str) None [source]¶
Unloads an extension.
- Parameters:
package (str) – The package to unload the extension from.
- property user: UserClient¶
returns: The bot’s user object :rtype: User
- Raises:
AttributeError – If used before the bot is ready
- user_command(name: str | None = None, *, guild_ids: list[Snowflake | int] | None = None, guild_install: bool = True, user_install: bool = False)[source]¶
Used to register a user command
Example usage
@user_command() async def content(ctx, user: Union[Member, User]): await ctx.send(f"Target: {user.name}")
- Parameters:
name (Optional[str]) – Name of the command, if not provided, it will use the function name
guild_ids (Optional[list[Union[Snowflake, int]]]) – List of guild IDs to register the command in
user_install (bool) – Whether the command can be installed by users or not
guild_install (bool) – Whether the command can be installed by guilds or not