Discord Bot Blocks

Blocks for interacting with Discord using bot tokens, including sending messages, managing threads, and reading channel data.

Create Discord Thread

What it is

Creates a new thread in a Discord channel.

How it works

This block uses the Discord API with a bot token to create a new thread in a specified channel. Threads can be public or private (private requires Boost Level 2+).

Configure auto-archive duration and optionally send an initial message when the thread is created.

Inputs

Input
Description
Type
Required

channel_name

Channel ID or channel name to create the thread in

str

Yes

server_name

Server name (only needed if using channel name)

str

No

thread_name

The name of the thread to create

str

Yes

is_private

Whether to create a private thread (requires Boost Level 2+) or public thread

bool

No

auto_archive_duration

Duration before the thread is automatically archived

"60" | "1440" | "4320" | "10080"

No

message_content

Optional initial message to send in the thread

str

No

Outputs

Output
Description
Type

error

Error message if the operation failed

str

status

Operation status

str

thread_id

ID of the created thread

str

thread_name

Name of the created thread

str

Possible use case

Support Tickets: Create threads for individual support conversations to keep channels organized.

Discussion Topics: Automatically create threads for new topics or announcements.

Project Channels: Spin up discussion threads for specific tasks or features.


Discord Channel Info

What it is

Resolves Discord channel names to IDs and vice versa.

How it works

This block resolves Discord channel identifiers, converting between channel names and IDs. It queries the Discord API to find the channel and returns comprehensive information including server details.

Useful for workflows that receive channel names but need IDs for other Discord operations.

Inputs

Input
Description
Type
Required

channel_identifier

Channel name or channel ID to look up

str

Yes

server_name

Server name (optional, helps narrow down search)

str

No

Outputs

Output
Description
Type

error

Error message if the operation failed

str

channel_id

The channel's ID

str

channel_name

The channel's name

str

server_id

The server's ID

str

server_name

The server's name

str

channel_type

Type of channel (text, voice, etc)

str

Possible use case

Dynamic Routing: Look up channel IDs to route messages to user-specified channels by name.

Validation: Verify channel existence before attempting to send messages.

Workflow Setup: Get channel details during workflow configuration.


Discord User Info

What it is

Gets information about a Discord user by their ID.

How it works

This block retrieves information about a Discord user by their ID. It queries the Discord API and returns profile details including username, display name, avatar, and account creation date.

The user must be visible to your bot (share a server with your bot).

Inputs

Input
Description
Type
Required

user_id

The Discord user ID to get information about

str

Yes

Outputs

Output
Description
Type

error

Error message if the operation failed

str

user_id

The user's ID (passed through for chaining)

str

username

The user's username

str

display_name

The user's display name

str

discriminator

The user's discriminator (if applicable)

str

avatar_url

URL to the user's avatar

str

is_bot

Whether the user is a bot

bool

created_at

When the account was created

str

Possible use case

User Profiling: Get user details to personalize responses or create user profiles.

Mention Resolution: Look up user information when processing mentions in messages.

Activity Logging: Retrieve user details for logging or analytics purposes.


Read Discord Messages

What it is

Reads messages from a Discord channel using a bot token.

How it works

The block uses a Discord bot to log into a server and listen for new messages. When a message is received, it extracts the content, channel name, and username of the sender. If the message contains a text file attachment, the block also retrieves and includes the file's content.

Outputs

Output
Description
Type

error

Error message if the operation failed

str

message_content

The content of the message received

str

message_id

The ID of the message

str

channel_id

The ID of the channel

str

channel_name

The name of the channel the message was received from

str

user_id

The ID of the user who sent the message

str

username

The username of the user who sent the message

str

Possible use case

This block could be used to monitor a Discord channel for support requests. When a user posts a message, the block captures it, allowing another part of the system to process and respond to the request.


Reply To Discord Message

What it is

Replies to a specific Discord message.

How it works

This block sends a reply to a specific Discord message, creating a threaded reply that references the original message. Optionally mention the original author to notify them.

The reply appears linked to the original message in Discord's UI, maintaining conversation context.

Inputs

Input
Description
Type
Required

channel_id

The channel ID where the message to reply to is located

str

Yes

message_id

The ID of the message to reply to

str

Yes

reply_content

The content of the reply

str

Yes

mention_author

Whether to mention the original message author

bool

No

Outputs

Output
Description
Type

error

Error message if the operation failed

str

status

Operation status

str

reply_id

ID of the reply message

str

Possible use case

Conversation Bots: Reply to user questions maintaining conversation context.

Support Responses: Respond to support requests by replying to the original message.

Interactive Commands: Reply to command messages with results or confirmations.


Send Discord DM

What it is

Sends a direct message to a Discord user using their user ID.

How it works

This block sends a direct message to a Discord user. It opens a DM channel with the user (if not already open) and sends the message. The user must allow DMs from server members or share a server with your bot.

Returns the message ID of the sent DM for tracking purposes.

Inputs

Input
Description
Type
Required

user_id

The Discord user ID to send the DM to (e.g., '123456789012345678')

str

Yes

message_content

The content of the direct message to send

str

Yes

Outputs

Output
Description
Type

error

Error message if the operation failed

str

status

The status of the operation

str

message_id

The ID of the sent message

str

Possible use case

Private Notifications: Send private alerts or notifications to specific users.

Welcome Messages: DM new server members with welcome information.

Verification Systems: Send verification codes or instructions via DM.


Send Discord Embed

What it is

Sends a rich embed message to a Discord channel.

How it works

This block sends a rich embed message to a Discord channel. Embeds support formatted content with titles, descriptions, colors, images, thumbnails, author sections, footers, and structured fields.

Configure the embed's appearance with colors, images, and multiple fields for organized information display.

Inputs

Input
Description
Type
Required

channel_identifier

Channel ID or channel name to send the embed to

str

Yes

server_name

Server name (only needed if using channel name)

str

No

title

The title of the embed

str

No

description

The main content/description of the embed

str

No

color

Embed color as integer (e.g., 0x00ff00 for green)

int

No

thumbnail_url

URL for the thumbnail image

str

No

image_url

URL for the main embed image

str

No

author_name

Author name to display

str

No

footer_text

Footer text

str

No

fields

List of field dictionaries with 'name', 'value', and optional 'inline' keys

List[Dict[str, Any]]

No

Outputs

Output
Description
Type

error

Error message if the operation failed

str

status

Operation status

str

message_id

ID of the sent embed message

str

Possible use case

Status Updates: Send formatted status updates with colors and structured information.

Data Displays: Present data in organized embed fields for easy reading.

Announcements: Create visually appealing announcements with images and branding.


Send Discord File

What it is

Sends a file attachment to a Discord channel.

How it works

This block uploads and sends a file attachment to a Discord channel. It supports various file types including images, documents, and other media. Files can be provided as URLs, data URIs, or local paths.

Optionally include a message along with the file attachment.

Inputs

Input
Description
Type
Required

channel_identifier

Channel ID or channel name to send the file to

str

Yes

server_name

Server name (only needed if using channel name)

str

No

file

The file to send (URL, data URI, or local path). Supports images, videos, documents, etc.

str (file)

Yes

filename

Name of the file when sent (e.g., 'report.pdf', 'image.png')

str

No

message_content

Optional message to send with the file

str

No

Outputs

Output
Description
Type

error

Error message if the operation failed

str

status

Operation status

str

message_id

ID of the sent message

str

Possible use case

Report Sharing: Send generated reports or documents to Discord channels.

Image Posting: Share images from workflows or external sources.

Backup Distribution: Share backup files or exports with team channels.


Send Discord Message

What it is

Sends a message to a Discord channel using a bot token.

How it works

The block uses a Discord bot to log into a server, locate the specified channel, and send the provided message. If the message is longer than Discord's character limit, it automatically splits the message into smaller chunks and sends them sequentially.

Inputs

Input
Description
Type
Required

message_content

The content of the message to send

str

Yes

channel_name

Channel ID or channel name to send the message to

str

Yes

server_name

Server name (only needed if using channel name)

str

No

Outputs

Output
Description
Type

error

Error message if the operation failed

str

status

The status of the operation (e.g., 'Message sent', 'Error')

str

message_id

The ID of the sent message

str

channel_id

The ID of the channel where the message was sent

str

Possible use case

This block could be used as part of an automated notification system. For example, it could send alerts to a Discord channel when certain events occur in another system, such as when a new user signs up or when a critical error is detected.


Last updated

Was this helpful?