<!-- Clearly explain the need for these changes: -->
we met some reality when merging into the docs site but this fixes it
### Changes 🏗️
updates paths, adds some guides
<!-- Concisely describe all of the changes made in this pull request:
-->
update to match reality
### Checklist 📋
#### For code changes:
- [x] I have clearly listed my changes in the PR description
- [x] I have made a test plan
- [x] I have tested my changes according to the test plan:
<!-- Put your test plan here: -->
- [x] deploy it and validate
<!-- CURSOR_SUMMARY -->
---
> [!NOTE]
> Aligns block integrations documentation with GitBook.
>
> - Changes generator default output to
`docs/integrations/block-integrations` and writes overview `README.md`
and `SUMMARY.md` at `docs/integrations/`
> - Adds GitBook frontmatter and hint syntax to overview; prefixes block
links with `block-integrations/`
> - Introduces `generate_summary_md` to build GitBook navigation
(including optional `guides/`)
> - Preserves per-block manual sections and adds optional `extras` +
file-level `additional_content`
> - Updates sync checker to validate parent `README.md` and `SUMMARY.md`
> - Rewrites `docs/integrations/README.md` with GitBook frontmatter and
updated links; adds `docs/integrations/SUMMARY.md`
> - Adds new guides: `guides/llm-providers.md`,
`guides/voice-providers.md`
>
> <sup>Written by [Cursor
Bugbot](https://cursor.com/dashboard?tab=bugbot) for commit
fdb7ff8111. This will update automatically
on new commits. Configure
[here](https://cursor.com/dashboard?tab=bugbot).</sup>
<!-- /CURSOR_SUMMARY -->
---------
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
Co-authored-by: claude[bot] <41898282+claude[bot]@users.noreply.github.com>
Co-authored-by: bobby.gaffin <bobby.gaffin@agpt.co>
13 KiB
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.