Channel

discord_http.channel module

class discord_http.channel.BaseChannel(*, state: DiscordAPI, data: dict, guild_id: int | None = None)[source]

Bases: PartialChannel

classmethod from_dict(*, state: DiscordAPI, data: dict, guild_id: int | None = None) BaseChannel[source]

Create a channel object from a dictionary Requires the state to be set

Parameters:
  • state (DiscordAPI) – The state to use

  • data (dict) – Data provided by Discord API

Returns:

The channel object

Return type:

BaseChannel

property mention: str

The channel’s mention

Type:

str

permissions_for(member: Member) Permissions[source]

Returns the permissions for a member in the channel. Note that this only works if you are using Gateway with guild, role and channel cache.

Parameters:

member (Member) – The member to get the permissions for.

Returns:

The permissions for the member in the channel.

Return type:

Permissions

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.CategoryChannel(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property channels: list[BaseChannel | PartialChannel]

Returns a list of channels in this category. This will only return channels that are in the same guild as the category.

Type:

list[BaseChannel | PartialChannel]

async create_stage_channel(name: str, **kwargs) StageChannel[source]

Create a stage channel

Parameters:
  • name (str) – The name of the channel

  • bitrate (Optional[int]) – The bitrate of the channel

  • user_limit (Optional[int]) – The user limit of the channel

  • overwrites (Optional[list[PermissionOverwrite]]) – The permission overwrites of the category

  • position (Optional[int]) – The position of the channel

  • video_quality_mode (Optional[Union[VideoQualityType, int]]) – The video quality mode of the channel

  • parent_id (Optional[Union[Snowflake, int]]) – The Category ID where the channel will be placed

  • reason (Optional[str]) – The reason for creating the stage channel

Returns:

The created channel

Return type:

StageChannel

async create_text_channel(name: str, **kwargs) TextChannel[source]

Create a text channel in the category

Parameters:
  • name (str) – The name of the channel

  • topic (Optional[str]) – The topic of the channel

  • rate_limit_per_user (Optional[int]) – The rate limit per user of the channel

  • overwrites (Optional[list[PermissionOverwrite]]) – The permission overwrites of the category

  • parent_id (Optional[Snowflake]) – The Category ID where the channel will be placed

  • nsfw (Optional[bool]) – Whether the channel is NSFW or not

  • reason (Optional[str]) – The reason for creating the text channel

Returns:

The channel object

Return type:

TextChannel

async create_voice_channel(name: str, **kwargs) VoiceChannel[source]

Create a voice channel to category

Parameters:
  • name (str) – The name of the channel

  • bitrate (Optional[int]) – The bitrate of the channel

  • user_limit (Optional[int]) – The user limit of the channel

  • rate_limit_per_user (Optional) – The rate limit per user of the channel

  • overwrites (Optional[list[PermissionOverwrite]]) – The permission overwrites of the category

  • position (Optional[int]) – The position of the channel

  • parent_id (Optional[Snowflake]) – The Category ID where the channel will be placed

  • nsfw (Optional[bool]) – Whether the channel is NSFW or not

  • reason (Optional[str]) – The reason for creating the voice channel

Returns:

The channel object

Return type:

VoiceChannel

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.DMChannel(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

async edit(*args, **kwargs) None[source]

Only here to prevent errors

Raises:

TypeError – If you try to edit a DM channel

property mention: str

The channel’s mention

Type:

str

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.DirectoryChannel(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.ForumChannel(state: DiscordAPI, data: dict)[source]

Bases: PublicThread

class discord_http.channel.ForumTag(*, data: dict)[source]

Bases: object

classmethod create(name: str | None = None, *, emoji_id: int | None = None, emoji_name: str | None = None, moderated: bool = False) ForumTag[source]

Create a forum tag, used for editing available_tags

Parameters:
  • name (Optional[str]) – The name of the tag

  • emoji_id (Optional[int]) – The emoji ID of the tag

  • emoji_name (Optional[str]) – The emoji name of the tag

  • moderated (bool) – If the tag is moderated

Returns:

The tag object

Return type:

ForumTag

classmethod from_data(*, data: dict) Self[source]
to_dict() dict[source]
class discord_http.channel.ForumThread(state: DiscordAPI, data: dict)[source]

Bases: PublicThread

class discord_http.channel.GroupDMChannel(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.NewsChannel(state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.NewsThread(state: DiscordAPI, data: dict)[source]

Bases: PublicThread

class discord_http.channel.PartialChannel(*, state: DiscordAPI, id: int, guild_id: int | None = None)[source]

Bases: PartialBase

async add_thread_member(user_id: int) None[source]

Add a thread member

Parameters:

user_id (int) – The user ID to add

async bulk_delete_messages(*, check: Callable[['Message'], bool] | None = None, before: datetime | Message | Snowflake | int | None = None, after: datetime | Message | Snowflake | int | None = None, around: datetime | Message | Snowflake | int | None = None, message_ids: list['Message | Snowflake | int'], limit: int | None = 100, reason: str | None = None) None[source]
async bulk_delete_messages(*, check: Callable[['Message'], bool] | None = None, before: datetime | Message | Snowflake | int | None = None, after: datetime | Message | Snowflake | int | None = None, around: datetime | Message | Snowflake | int | None = None, message_ids: None = None, limit: int | None = 100, reason: str | None = None) list['Message']

Deletes messages in bulk

Parameters:
  • check (Callable[[Message], bool] | None) – A function to check if the message should be deleted

  • before (datetime | Message | Snowflake | int | None) – The message before which to delete

  • after (datetime | Message | Snowflake | int | None) – The message after which to delete

  • around (datetime | Message | Snowflake | int | None) – The message around which to delete

  • message_ids (list[Message | Snowflake | int] | None) – The message IDs to delete

  • limit (int | None) – The maximum amount of messages to delete

  • reason (str | None) – The reason for deleting the messages

Returns:

Returns a list of messages deleted If you provide message_ids upfront, it will skip history search and delete

Return type:

list[Message] | None

property channel: BaseChannel | CategoryChannel | PartialChannel | None

BaseChannel | CategoryChannel | PartialChannel | None: Returns the channel the thread is in. Only returns a full object if cache is enabled for guild and channel.

async create_forum_or_media(name: str, *, content: str | None = None, embed: Embed | None = None, embeds: list[Embed] | None = None, file: File | None = None, files: list[File] | None = None, allowed_mentions: AllowedMentions | None = None, view: View | None = None, auto_archive_duration: int | None = 4320, rate_limit_per_user: int | None = None, applied_tags: list[ForumTag | int] | None = None) ForumThread[source]

Create a forum or media thread in the channel

Parameters:
  • name (str) – The name of the thread

  • content (Optional[str]) – The content of the message

  • embed (Optional[Embed]) – Embed to be sent

  • embeds (Optional[list[Embed]]) – List of embeds to be sent

  • file (Optional[File]) – File to be sent

  • files (Optional[list[File]]) – List of files to be sent

  • allowed_mentions (Optional[AllowedMentions]) – The allowed mentions for the message

  • view (Optional[View]) – The view to be sent

  • auto_archive_duration (Optional[int]) – The duration in minutes to automatically archive the thread after recent activity

  • rate_limit_per_user (Optional[int]) – How long the slowdown should be

  • applied_tags (Optional[list[Union["ForumTag", int]]]) – The tags to be applied to the thread

Returns:

_description_

Return type:

ForumThread

async create_invite(*, max_age: timedelta | int = 86400, max_uses: int | None = 0, temporary: bool = False, unique: bool = False) Invite[source]

Create an invite for the channel

Parameters:
  • max_age (Union[timedelta, int]) – How long the invite should last

  • temporary (bool) – If the invite should be temporary

  • unique (bool) – If the invite should be unique

Returns:

The invite object

Return type:

Invite

async create_thread(name: str, *, type: ChannelType | int = ChannelType.guild_private_thread, auto_archive_duration: int | None = 4320, invitable: bool = True, rate_limit_per_user: timedelta | int | None = None, reason: str | None = None) PublicThread | PrivateThread | NewsThread[source]

Creates a thread in the channel

Parameters:
  • name (str) – The name of the thread

  • type (Optional[Union[ChannelType, int]]) – The type of thread to create

  • auto_archive_duration (Optional[int]) – The duration in minutes to automatically archive the thread after recent activity

  • invitable (bool) – If the thread is invitable

  • rate_limit_per_user (Optional[Union[timedelta, int]]) – How long the slowdown should be

  • reason (Optional[str]) – The reason for creating the thread

Returns:

The thread object

Return type:

Union[PublicThread, PrivateThread, NewsThread]

Raises:

ValueError

  • If the auto_archive_duration is not 60, 1440, 4320 or 10080 - If the rate_limit_per_user is not between 0 and 21600 seconds

async create_webhook(name: str, *, avatar: File | bytes | None = None, reason: str | None = None) Webhook[source]

Create a webhook for the channel

Parameters:
  • name (str) – The name of the webhook

  • avatar (Optional[File]) – The avatar of the webhook

  • reason (Optional[str]) – The reason for creating the webhook that appears in audit logs

Returns:

The webhook object

Return type:

Webhook

async delete(*, reason: str | None = None) None[source]

Delete the channel

Parameters:

reason (Optional[str]) – The reason for deleting the channel

async delete_permission(id: Snowflake | int, *, reason: str | None = None) None[source]

Delete a permission overwrite for the channel

Parameters:
  • id (Union[Snowflake, int]) – The ID of the overwrite

  • reason (Optional[str]) – The reason for deleting the overwrite

async edit(*, name: str | None = <MISSING>, type: ~discord_http.enums.ChannelType | int | None = <MISSING>, position: int | None = <MISSING>, topic: str | None = <MISSING>, nsfw: bool | None = <MISSING>, rate_limit_per_user: int | None = <MISSING>, bitrate: int | None = <MISSING>, user_limit: int | None = <MISSING>, overwrites: list[~discord_http.flags.PermissionOverwrite] | None = <MISSING>, parent_id: ~discord_http.object.Snowflake | int | None = <MISSING>, rtc_region: str | None = <MISSING>, video_quality_mode: ~discord_http.enums.VideoQualityType | int | None = <MISSING>, default_auto_archive_duration: int | None = <MISSING>, flags: ~discord_http.flags.ChannelFlags | None = <MISSING>, available_tags: list[~discord_http.channel.ForumTag] | None = <MISSING>, default_reaction_emoji: str | None = <MISSING>, default_thread_rate_limit_per_user: int | None = <MISSING>, default_sort_order: ~discord_http.enums.SortOrderType | int | None = <MISSING>, default_forum_layout: ~discord_http.enums.ForumLayoutType | int | None = <MISSING>, archived: bool | None = <MISSING>, auto_archive_duration: int | None = <MISSING>, locked: bool | None = <MISSING>, invitable: bool | None = <MISSING>, applied_tags: list[~discord_http.channel.ForumTag | int] | None = <MISSING>, reason: str | None = None) Self[source]

Edit the channel

Note that this method globaly edits any channel type. So be sure to use the correct parameters for the channel.

Parameters:
  • name (Optional[str]) – New name of the channel (All)

  • type (Optional[Union[ChannelType, int]]) – The new type of the channel (Text, Announcement)

  • position (Optional[int]) – The new position of the channel (All)

  • topic (Optional[str]) – The new topic of the channel (Text, Announcement, Forum, Media)

  • nsfw (Optional[bool]) – If the channel should be NSFW (Text, Voice, Announcement, Stage, Forum, Media)

  • rate_limit_per_user (Optional[int]) – How long the slowdown should be (Text, Voice, Stage, Forum, Media)

  • bitrate (Optional[int]) – The new bitrate of the channel (Voice, Stage)

  • user_limit (Optional[int]) – The new user limit of the channel (Voice, Stage)

  • overwrites (Optional[list[PermissionOverwrite]]) – The new permission overwrites of the channel (All)

  • parent_id (Optional[Union[Snowflake, int]]) – The new parent ID of the channel (Text, Voice, Announcement, Stage, Forum, Media)

  • rtc_region (Optional[str]) – The new RTC region of the channel (Voice, Stage)

  • video_quality_mode (Optional[Union[VideoQualityType, int]]) – The new video quality mode of the channel (Voice, Stage)

  • default_auto_archive_duration (Optional[int]) – The new default auto archive duration of the channel (Text, Announcement, Forum, Media)

  • flags (Optional[ChannelFlags]) – The new flags of the channel (Forum, Media)

  • available_tags (Optional[list[ForumTag]]) – The new available tags of the channel (Forum, Media)

  • default_reaction_emoji (Optional[str]) – The new default reaction emoji of the channel (Forum, Media)

  • default_thread_rate_limit_per_user (Optional[int]) – The new default thread rate limit per user of the channel (Text, Forum, Media)

  • default_sort_order (Optional[Union[SortOrderType, int]]) – The new default sort order of the channel (Forum, Media)

  • default_forum_layout (Optional[Union[ForumLayoutType, int]]) – The new default forum layout of the channel (Forum)

  • archived (Optional[bool]) – If the thread should be archived (Thread, Forum)

  • auto_archive_duration (Optional[int]) – The new auto archive duration of the thread (Thread, Forum)

  • locked (Optional[bool]) – If the thread should be locked (Thread, Forum)

  • invitable (Optional[bool]) – If the thread should be invitable by everyone (Thread)

  • applied_tags (Optional[list[Union[ForumTag, int]]) – The new applied tags of the forum thread (Forum, Media)

  • reason (Optional[str]) – The reason for editing the channel (All)

Returns:

The channel object

Return type:

BaseChannel

async fetch() BaseChannel[source]

BaseChannel: Fetches the channel and returns the channel object

async fetch_archived_private_threads(*, client: bool = False) list[PrivateThread][source]

Fetch all archived private threads

Parameters:

client (bool) – If it should fetch only where the client is a member of the thread

Returns:

The list of private threads

Return type:

list[PrivateThread]

async fetch_archived_public_threads() list[PublicThread][source]

Fetch all archived public threads

Returns:

The list of public threads

Return type:

list[PublicThread]

async fetch_history(*, before: datetime | Message | Snowflake | int | None = None, after: datetime | Message | Snowflake | int | None = None, around: datetime | Message | Snowflake | int | None = None, limit: int | None = 100) AsyncIterator[Message][source]

Fetch the channel’s message history

Parameters:
  • before (Optional[Union[datetime, Message, Snowflake, int]]) – Get messages before this message

  • after (Optional[Union[datetime, Message, Snowflake, int]]) – Get messages after this message

  • around (Optional[Union[datetime, Message, Snowflake, int]]) – Get messages around this message

  • limit (Optional[int]) – The maximum amount of messages to fetch. None will fetch all users.

Yields:

Message – The message object

async fetch_message(message_id: int) Message[source]

Fetch a message from the channel

Parameters:

message_id (int) – The message ID to fetch

Returns:

The message object

Return type:

Message

async fetch_pins() list[Message][source]

Fetch all pinned messages for the channel in question

Returns:

The list of pinned messages

Return type:

list[Message]

async fetch_thread_member(user_id: int) ThreadMember[source]

Fetch a thread member

Parameters:

user_id (int) – The user ID to fetch

Returns:

The thread member object

Return type:

ThreadMember

async fetch_thread_members() list[ThreadMember][source]

Fetch all thread members

Returns:

The list of thread members

Return type:

list[ThreadMember]

async follow_announcement_channel(source_channel_id: Snowflake | int) None[source]

Follow an announcement channel to send messages to the webhook

Parameters:

source_channel_id (int) – The channel ID to follow

classmethod from_dict(*, state: DiscordAPI, data: dict) Self[source]

Create a channel object from a dictionary Requires the state to be set

Parameters:
  • state (DiscordAPI) – The state to use

  • data (dict) – Data provided by Discord API

Returns:

The channel object

Return type:

BaseChannel

get_partial_message(message_id: int) PartialMessage[source]

Get a partial message object from the channel

Parameters:

message_id (int) – The message ID to get the partial message from

Returns:

The partial message object

Return type:

PartialMessage

property guild: Guild | PartialGuild | None

Optional[Guild | PartialGuild]: The guild the channel belongs to (if available). If you are using gateway cache, it can return full object too

async join_thread() None[source]

Make the bot join a thread

async leave_thread() None[source]

Make the bot leave a thread

property mention: str

The channel’s mention

Type:

str

property parent: BaseChannel | CategoryChannel | PartialChannel | None

BaseChannel | CategoryChannel | PartialChannel | None: Returns the parent channel of the thread or the parent category of the channel. Only returns a full object if cache is enabled for guild and channel.

permissions_for(member: Member) Permissions[source]

Returns the permissions for a member in the channel. However since this is Partial, it will always return Permissions.none()

Parameters:

member (Member) – The member to get the permissions for.

Returns:

The permissions for the member in the channel.

Return type:

Permissions

async remove_thread_member(user_id: int) None[source]

Remove a thread member

Parameters:

user_id (int) – The user ID to remove

async send(content: str | None = <MISSING>, *, embed: ~discord_http.embeds.Embed | None = <MISSING>, embeds: list[~discord_http.embeds.Embed] | None = <MISSING>, file: ~discord_http.file.File | None = <MISSING>, files: list[~discord_http.file.File] | None = <MISSING>, view: ~discord_http.view.View | None = <MISSING>, tts: bool | None = False, type: ~discord_http.enums.ResponseType | int = 4, poll: Poll | None = <MISSING>, allowed_mentions: ~discord_http.mentions.AllowedMentions | None = <MISSING>, delete_after: float | None = None) Message[source]

Send a message to the channel

Parameters:
  • content (Optional[str]) – Cotnent of the message

  • embed (Optional[Embed]) – Includes an embed object

  • embeds (Optional[list[Embed]]) – List of embed objects

  • file (Optional[File]) – A file object

  • files (Union[list[File], File]) – A list of file objects

  • view (View) – Send components to the message

  • tts (bool) – If the message should be sent as a TTS message

  • type (Optional[ResponseType]) – The type of response to the message

  • allowed_mentions (Optional[AllowedMentions]) – The allowed mentions for the message

  • poll (Optional[Poll]) – The poll to be sent

  • delete_after (Optional[float]) – How long to wait before deleting the message

Returns:

The message object

Return type:

Message

async set_permission(overwrite: PermissionOverwrite, *, reason: str | None = None) None[source]

Set a permission overwrite for the channel

Parameters:
  • overwrite (PermissionOverwrite) – The new overwrite permissions for the spesific role/user

  • reason (Optional[str]) – The reason for editing the overwrite

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

typing() Typing[source]

Makes the bot trigger the typing indicator. There are two ways you can use this:

  • Usual await call

  • Using async with to type as long as you need

# Method 1
await channel.typing()  # Stops after 10 seconds or message sent

# Method 2
async with channel.typing():
    asyncio.sleep(4)
class discord_http.channel.PartialThread(*, state: DiscordAPI, id: int, guild_id: int, parent_id: int, type: ChannelType | int)[source]

Bases: PartialChannel

class discord_http.channel.PrivateThread(*, state: DiscordAPI, data: dict)[source]

Bases: PublicThread

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.PublicThread(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property guild: Guild | PartialGuild | None

Returns a partial guild object

Type:

PartialGuild

property last_message: PartialMessage | None

Returns a partial message object if the last message ID is available

Type:

Optional[PartialMessage]

property owner: PartialUser | None

Returns a partial user object

Type:

PartialUser

class discord_http.channel.StageChannel(*, state: DiscordAPI, data: dict)[source]

Bases: VoiceChannel

async create_stage_instance(*, topic: str, privacy_level: ~discord_http.enums.PrivacyLevelType = <MISSING>, send_start_notification: bool = <MISSING>, guild_scheduled_event: ~discord_http.object.Snowflake | int = <MISSING>, reason: str | None = None) StageInstance[source]

Create a stage instance

Parameters:
  • topic (str) – The topic of the stage instance

  • privacy_level (PrivacyLevelType) – The privacy level of the stage instance. Defaults to PrivacyLevelType.guild_only

  • send_start_notification (bool) – Whether to notify @everyone that the stage instance has started.

  • guild_scheduled_event (Optional[Snowflake | int]) – The guild scheduled event to associate with this stage instance.

  • reason (Optional[str]) – The reason for creating the stage instance

Returns:

The created stage instance

Return type:

StageInstance

async fetch_stage_instance() StageInstance[source]

Fetch the stage instance associated with this stage channel

Returns:

The stage instance of the channel

Return type:

StageInstance

property stage_instance: StageInstance | None

Returns the stage instance for this channel, if available and cached.

Type:

Optional[StageInstance]

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.StoreChannel(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.TextChannel(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.Thread(*, state: DiscordAPI, data: dict)[source]

Bases: PublicThread

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.VoiceChannel(*, state: DiscordAPI, data: dict)[source]

Bases: BaseChannel

property type: ChannelType

Returns the channel’s type

Type:

ChannelType

class discord_http.channel.VoiceRegion(*, data: dict)[source]

Bases: object