discord-automation

Compare original and translation side by side

🇺🇸

Original

English
🇨🇳

Translation

Chinese

Discord Automation via Rube MCP

通过Rube MCP实现Discord自动化

Automate Discord operations through Composio's Discord/Discordbot toolkits via Rube MCP.
通过Rube MCP,借助Composio的Discord/Discordbot工具包自动化Discord操作。

Prerequisites

前提条件

  • Rube MCP must be connected (RUBE_SEARCH_TOOLS available)
  • Active Discord connection via
    RUBE_MANAGE_CONNECTIONS
    with toolkits
    discord
    and
    discordbot
  • Always call
    RUBE_SEARCH_TOOLS
    first to get current tool schemas
  • 必须已连接Rube MCP(需支持RUBE_SEARCH_TOOLS)
  • 通过
    RUBE_MANAGE_CONNECTIONS
    完成Discord的活跃连接,需绑定工具包
    discord
    discordbot
  • 请始终先调用
    RUBE_SEARCH_TOOLS
    获取最新的工具架构

Setup

设置步骤

Get Rube MCP: Add
https://rube.app/mcp
as an MCP server in your client configuration. No API keys needed — just add the endpoint and it works.
  1. Verify Rube MCP is available by confirming
    RUBE_SEARCH_TOOLS
    responds
  2. Call
    RUBE_MANAGE_CONNECTIONS
    with toolkit
    discordbot
    (bot operations) or
    discord
    (user operations)
  3. If connection is not ACTIVE, follow the returned auth link to complete Discord auth
  4. Confirm connection status shows ACTIVE before running any workflows
获取Rube MCP:在客户端配置中添加
https://rube.app/mcp
作为MCP服务器。无需API密钥 —— 只需添加端点即可使用。
  1. 确认Rube MCP可用:检查
    RUBE_SEARCH_TOOLS
    是否能正常响应
  2. 调用
    RUBE_MANAGE_CONNECTIONS
    ,选择工具包
    discordbot
    (机器人操作)或
    discord
    (用户操作)
  3. 如果连接状态未显示为ACTIVE,请按照返回的授权链接完成Discord授权
  4. 在运行任何工作流之前,确认连接状态显示为ACTIVE

Core Workflows

核心工作流

1. Send Messages

1. 发送消息

When to use: User wants to send messages to channels or DMs
Tool sequence:
  1. DISCORD_LIST_MY_GUILDS
    - List guilds the bot belongs to [Prerequisite]
  2. DISCORDBOT_LIST_GUILD_CHANNELS
    - List channels in a guild [Prerequisite]
  3. DISCORDBOT_CREATE_MESSAGE
    - Send a message [Required]
  4. DISCORDBOT_UPDATE_MESSAGE
    - Edit a sent message [Optional]
Key parameters:
  • channel_id
    : Channel snowflake ID
  • content
    : Message text (max 2000 characters)
  • embeds
    : Array of embed objects for rich content
  • guild_id
    : Guild ID for channel listing
Pitfalls:
  • Bot must have SEND_MESSAGES permission in the channel
  • High-frequency sends can hit per-route rate limits; respect Retry-After headers
  • Only messages sent by the same bot can be edited
适用场景:用户需要向频道或私信发送消息
工具执行顺序:
  1. DISCORD_LIST_MY_GUILDS
    - 列出机器人所属的服务器 [前提步骤]
  2. DISCORDBOT_LIST_GUILD_CHANNELS
    - 列出服务器内的频道 [前提步骤]
  3. DISCORDBOT_CREATE_MESSAGE
    - 发送消息 [必需步骤]
  4. DISCORDBOT_UPDATE_MESSAGE
    - 编辑已发送的消息 [可选步骤]
关键参数:
  • channel_id
    : 频道的雪花ID
  • content
    : 消息文本(最多2000字符)
  • embeds
    : 用于富文本内容的嵌入对象数组
  • guild_id
    : 用于频道列表的服务器ID
注意事项:
  • 机器人必须拥有频道的SEND_MESSAGES权限
  • 高频发送可能触发路由级别的速率限制;请遵守Retry-After响应头
  • 仅能编辑同一机器人发送的消息

2. Send Direct Messages

2. 发送私信

When to use: User wants to DM a Discord user
Tool sequence:
  1. DISCORDBOT_CREATE_DM
    - Create or get DM channel [Required]
  2. DISCORDBOT_CREATE_MESSAGE
    - Send message to DM channel [Required]
Key parameters:
  • recipient_id
    : User snowflake ID for DM
  • channel_id
    : DM channel ID from CREATE_DM
Pitfalls:
  • Cannot DM users who have DMs disabled or have blocked the bot
  • CREATE_DM returns existing channel if one already exists
适用场景:用户需要给Discord用户发送私信
工具执行顺序:
  1. DISCORDBOT_CREATE_DM
    - 创建或获取私信频道 [必需步骤]
  2. DISCORDBOT_CREATE_MESSAGE
    - 向私信频道发送消息 [必需步骤]
关键参数:
  • recipient_id
    : 接收私信用户的雪花ID
  • channel_id
    : 来自CREATE_DM接口返回的私信频道ID
注意事项:
  • 无法向已禁用私信或已屏蔽机器人的用户发送消息
  • 如果已存在私信频道,CREATE_DM会直接返回该频道

3. Manage Roles

3. 管理角色

When to use: User wants to create, assign, or remove roles
Tool sequence:
  1. DISCORDBOT_CREATE_GUILD_ROLE
    - Create a new role [Optional]
  2. DISCORDBOT_ADD_GUILD_MEMBER_ROLE
    - Assign role to member [Optional]
  3. DISCORDBOT_DELETE_GUILD_ROLE
    - Delete a role [Optional]
  4. DISCORDBOT_GET_GUILD_MEMBER
    - Get member details [Optional]
  5. DISCORDBOT_UPDATE_GUILD_MEMBER
    - Update member (roles, nick, etc.) [Optional]
Key parameters:
  • guild_id
    : Guild snowflake ID
  • user_id
    : User snowflake ID
  • role_id
    : Role snowflake ID
  • name
    : Role name
  • permissions
    : Bitwise permission value
  • color
    : RGB color integer
Pitfalls:
  • Role assignment requires MANAGE_ROLES permission
  • Target role must be lower in hierarchy than bot's highest role
  • DELETE permanently removes the role from all members
适用场景:用户需要创建、分配或删除角色
工具执行顺序:
  1. DISCORDBOT_CREATE_GUILD_ROLE
    - 创建新角色 [可选步骤]
  2. DISCORDBOT_ADD_GUILD_MEMBER_ROLE
    - 为成员分配角色 [可选步骤]
  3. DISCORDBOT_DELETE_GUILD_ROLE
    - 删除角色 [可选步骤]
  4. DISCORDBOT_GET_GUILD_MEMBER
    - 获取成员详情 [可选步骤]
  5. DISCORDBOT_UPDATE_GUILD_MEMBER
    - 更新成员信息(角色、昵称等) [可选步骤]
关键参数:
  • guild_id
    : 服务器的雪花ID
  • user_id
    : 用户的雪花ID
  • role_id
    : 角色的雪花ID
  • name
    : 角色名称
  • permissions
    : 权限的按位整数值
  • color
    : RGB颜色的整数值
注意事项:
  • 分配角色需要拥有MANAGE_ROLES权限
  • 目标角色的层级必须低于机器人的最高角色
  • 删除操作会永久移除所有成员的该角色

4. Manage Webhooks

4. 管理Webhook

When to use: User wants to create or use webhooks for external integrations
Tool sequence:
  1. DISCORDBOT_GET_GUILD_WEBHOOKS
    /
    DISCORDBOT_LIST_CHANNEL_WEBHOOKS
    - List webhooks [Optional]
  2. DISCORDBOT_CREATE_WEBHOOK
    - Create a new webhook [Optional]
  3. DISCORDBOT_EXECUTE_WEBHOOK
    - Send message via webhook [Optional]
  4. DISCORDBOT_UPDATE_WEBHOOK
    - Update webhook settings [Optional]
Key parameters:
  • webhook_id
    : Webhook ID
  • webhook_token
    : Webhook secret token
  • channel_id
    : Channel for webhook creation
  • name
    : Webhook name
  • content
    /
    embeds
    : Message content for execution
Pitfalls:
  • Webhook tokens are secrets; handle securely
  • Webhooks can post with custom username and avatar per message
  • MANAGE_WEBHOOKS permission required for creation
适用场景:用户需要创建或使用Webhook进行外部集成
工具执行顺序:
  1. DISCORDBOT_GET_GUILD_WEBHOOKS
    /
    DISCORDBOT_LIST_CHANNEL_WEBHOOKS
    - 列出Webhook [可选步骤]
  2. DISCORDBOT_CREATE_WEBHOOK
    - 创建新Webhook [可选步骤]
  3. DISCORDBOT_EXECUTE_WEBHOOK
    - 通过Webhook发送消息 [可选步骤]
  4. DISCORDBOT_UPDATE_WEBHOOK
    - 更新Webhook设置 [可选步骤]
关键参数:
  • webhook_id
    : Webhook的ID
  • webhook_token
    : Webhook的密钥令牌
  • channel_id
    : 用于创建Webhook的频道ID
  • name
    : Webhook名称
  • content
    /
    embeds
    : 执行时的消息内容
注意事项:
  • Webhook令牌是敏感信息;请安全处理
  • Webhook可在每条消息中自定义用户名和头像
  • 创建Webhook需要拥有MANAGE_WEBHOOKS权限

5. Manage Reactions

5. 管理消息反应

When to use: User wants to view or manage message reactions
Tool sequence:
  1. DISCORDBOT_LIST_MESSAGE_REACTIONS_BY_EMOJI
    - List users who reacted [Optional]
  2. DISCORDBOT_DELETE_ALL_MESSAGE_REACTIONS
    - Remove all reactions [Optional]
  3. DISCORDBOT_DELETE_ALL_MESSAGE_REACTIONS_BY_EMOJI
    - Remove specific emoji reactions [Optional]
  4. DISCORDBOT_DELETE_USER_MESSAGE_REACTION
    - Remove specific user's reaction [Optional]
Key parameters:
  • channel_id
    : Channel ID
  • message_id
    : Message snowflake ID
  • emoji_name
    : URL-encoded emoji or
    name:id
    for custom emojis
  • user_id
    : User ID for specific reaction removal
Pitfalls:
  • Unicode emojis must be URL-encoded (e.g., '%F0%9F%91%8D' for thumbs up)
  • Custom emojis use
    name:id
    format
  • DELETE_ALL requires MANAGE_MESSAGES permission
适用场景:用户需要查看或管理消息的反应
工具执行顺序:
  1. DISCORDBOT_LIST_MESSAGE_REACTIONS_BY_EMOJI
    - 列出已反应的用户 [可选步骤]
  2. DISCORDBOT_DELETE_ALL_MESSAGE_REACTIONS
    - 移除所有反应 [可选步骤]
  3. DISCORDBOT_DELETE_ALL_MESSAGE_REACTIONS_BY_EMOJI
    - 移除特定表情的反应 [可选步骤]
  4. DISCORDBOT_DELETE_USER_MESSAGE_REACTION
    - 移除特定用户的反应 [可选步骤]
关键参数:
  • channel_id
    : 频道ID
  • message_id
    : 消息的雪花ID
  • emoji_name
    : URL编码的表情符号,或自定义表情的
    name:id
    格式
  • user_id
    : 用于移除特定用户反应的用户ID
注意事项:
  • Unicode表情必须进行URL编码(例如,点赞表情为'%F0%9F%91%8D')
  • 自定义表情使用
    name:id
    格式
  • 删除所有反应需要拥有MANAGE_MESSAGES权限

Common Patterns

通用模式

Snowflake IDs

雪花ID

Discord uses snowflake IDs (64-bit integers as strings) for all entities:
  • Guilds, channels, users, roles, messages, webhooks
Discord为所有实体使用雪花ID(以字符串形式存储的64位整数):
  • 服务器、频道、用户、角色、消息、Webhook

Permission Bitfields

权限位字段

Permissions are combined using bitwise OR:
  • SEND_MESSAGES = 0x800
  • MANAGE_ROLES = 0x10000000
  • MANAGE_MESSAGES = 0x2000
  • ADMINISTRATOR = 0x8
权限通过按位OR运算组合:
  • SEND_MESSAGES = 0x800
  • MANAGE_ROLES = 0x10000000
  • MANAGE_MESSAGES = 0x2000
  • ADMINISTRATOR = 0x8

Pagination

分页

  • Most list endpoints support
    limit
    ,
    before
    ,
    after
    parameters
  • Messages: max 100 per request
  • Reactions: max 100 per request, use
    after
    for pagination
  • 大多数列表接口支持
    limit
    before
    after
    参数
  • 消息:每次请求最多100条
  • 反应:每次请求最多100条,使用
    after
    参数进行分页

Known Pitfalls

已知注意事项

Bot vs User Tokens:
  • discordbot
    toolkit uses bot tokens;
    discord
    uses user OAuth
  • Bot operations are preferred for automation
Rate Limits:
  • Discord enforces per-route rate limits
  • Respect
    Retry-After
    headers on 429 responses
机器人令牌 vs 用户令牌:
  • discordbot
    工具包使用机器人令牌;
    discord
    使用用户OAuth令牌
  • 自动化操作优先使用机器人令牌
速率限制:
  • Discord对每个路由实施速率限制
  • 收到429响应时,请遵守
    Retry-After
    响应头

Quick Reference

快速参考

TaskTool SlugKey Params
List guildsDISCORD_LIST_MY_GUILDS(none)
List channelsDISCORDBOT_LIST_GUILD_CHANNELSguild_id
Send messageDISCORDBOT_CREATE_MESSAGEchannel_id, content
Edit messageDISCORDBOT_UPDATE_MESSAGEchannel_id, message_id
Get messagesDISCORDBOT_LIST_MESSAGESchannel_id, limit
Create DMDISCORDBOT_CREATE_DMrecipient_id
Create roleDISCORDBOT_CREATE_GUILD_ROLEguild_id, name
Assign roleDISCORDBOT_ADD_GUILD_MEMBER_ROLEguild_id, user_id, role_id
Delete roleDISCORDBOT_DELETE_GUILD_ROLEguild_id, role_id
Get memberDISCORDBOT_GET_GUILD_MEMBERguild_id, user_id
Update memberDISCORDBOT_UPDATE_GUILD_MEMBERguild_id, user_id
Get guildDISCORDBOT_GET_GUILDguild_id
Create webhookDISCORDBOT_CREATE_WEBHOOKchannel_id, name
Execute webhookDISCORDBOT_EXECUTE_WEBHOOKwebhook_id, webhook_token
List webhooksDISCORDBOT_GET_GUILD_WEBHOOKSguild_id
Get reactionsDISCORDBOT_LIST_MESSAGE_REACTIONS_BY_EMOJIchannel_id, message_id, emoji_name
Clear reactionsDISCORDBOT_DELETE_ALL_MESSAGE_REACTIONSchannel_id, message_id
Test authDISCORDBOT_TEST_AUTH(none)
Get channelDISCORDBOT_GET_CHANNELchannel_id

Powered by Composio
任务工具标识关键参数
列出服务器DISCORD_LIST_MY_GUILDS
列出频道DISCORDBOT_LIST_GUILD_CHANNELSguild_id
发送消息DISCORDBOT_CREATE_MESSAGEchannel_id, content
编辑消息DISCORDBOT_UPDATE_MESSAGEchannel_id, message_id
获取消息DISCORDBOT_LIST_MESSAGESchannel_id, limit
创建私信DISCORDBOT_CREATE_DMrecipient_id
创建角色DISCORDBOT_CREATE_GUILD_ROLEguild_id, name
分配角色DISCORDBOT_ADD_GUILD_MEMBER_ROLEguild_id, user_id, role_id
删除角色DISCORDBOT_DELETE_GUILD_ROLEguild_id, role_id
获取成员信息DISCORDBOT_GET_GUILD_MEMBERguild_id, user_id
更新成员信息DISCORDBOT_UPDATE_GUILD_MEMBERguild_id, user_id
获取服务器信息DISCORDBOT_GET_GUILDguild_id
创建WebhookDISCORDBOT_CREATE_WEBHOOKchannel_id, name
执行WebhookDISCORDBOT_EXECUTE_WEBHOOKwebhook_id, webhook_token
列出WebhookDISCORDBOT_GET_GUILD_WEBHOOKSguild_id
获取反应列表DISCORDBOT_LIST_MESSAGE_REACTIONS_BY_EMOJIchannel_id, message_id, emoji_name
清除所有反应DISCORDBOT_DELETE_ALL_MESSAGE_REACTIONSchannel_id, message_id
测试授权DISCORDBOT_TEST_AUTH
获取频道信息DISCORDBOT_GET_CHANNELchannel_id

Composio 提供支持