Discord MCP Server
Provides 33 tools for managing Discord servers, including channel and role administration, member moderation, and complex multi-step administrative workflows. It features built-in rate limiting and uses direct Discord REST API calls for efficient server operations.
README
Discord MCP Server
An MCP server that exposes Discord admin operations as tools. Built with TypeScript + Bun, using direct Discord REST API v10 calls (no discord.js dependency).
Features
- 33 tools for Discord server administration
- Channel management, role management, member moderation, server configuration
- Composite tools for common multi-step workflows (category setup, channel lockdown, bulk role assignment)
- Built-in rate limiting with per-route bucket tracking and automatic retry
- Audit log reasons for all write operations via
X-Audit-Log-Reasonheader
Prerequisites
- Bun v1.0+
- A Discord bot token with appropriate permissions
Discord Bot Setup
- Go to https://discord.com/developers/applications
- Create a new application
- Go to the Bot tab, create a bot, and copy the token
- Enable required intents: Server Members Intent (needed for member listing)
- Go to OAuth2 > URL Generator
- Select scopes:
bot - Select permissions: Administrator (or granular permissions: Manage Channels, Manage Roles, Kick Members, Ban Members, Manage Guild, Moderate Members)
- Copy the generated invite URL and add the bot to your server
- Copy the Guild ID (right-click the server name in Discord > Copy Server ID -- requires Developer Mode enabled in Discord settings)
Installation
git clone <repo-url>
cd discord-mcp
bun install
Configuration
cp .env.example .env
# Edit .env with your bot token and optional guild ID
Environment variables:
| Variable | Required | Description |
|---|---|---|
DISCORD_BOT_TOKEN |
Yes | Your Discord bot token |
DISCORD_GUILD_ID |
No | Default guild ID. If set, tools will use this as the default and the guild_id parameter becomes optional. |
Usage with Claude Code
Add the following to .claude/mcp.json:
{
"mcpServers": {
"discord": {
"command": "bun",
"args": ["run", "/absolute/path/to/discord-mcp/src/index.ts"],
"env": {
"DISCORD_BOT_TOKEN": "your-token-here",
"DISCORD_GUILD_ID": "your-guild-id"
}
}
}
}
Usage with Claude Desktop
Add the following to claude_desktop_config.json:
{
"mcpServers": {
"discord": {
"command": "bun",
"args": ["run", "/absolute/path/to/discord-mcp/src/index.ts"],
"env": {
"DISCORD_BOT_TOKEN": "your-token-here",
"DISCORD_GUILD_ID": "your-guild-id"
}
}
}
}
Testing with MCP Inspector
bunx @modelcontextprotocol/inspector -- bun run src/index.ts
Tool Reference
Server Info (3 tools)
| Tool | Description |
|---|---|
get_guild |
Get detailed server information including member counts, features, and boost status |
get_guild_preview |
Get server preview with emojis, stickers, and approximate counts |
modify_guild |
Update server settings (name, description, verification level, icon, banner, system channel) |
Channels (7 tools)
| Tool | Description |
|---|---|
list_channels |
List all channels in a guild, grouped by category |
get_channel |
Get detailed information about a specific channel |
create_channel |
Create a new channel (text, voice, category, announcement, stage, forum, media) |
modify_channel |
Modify a channel's settings (name, topic, position, parent, NSFW) |
delete_channel |
Permanently delete a channel |
set_channel_permissions |
Set permission overwrites for a role or member on a channel |
delete_channel_permissions |
Remove a permission overwrite for a role or member on a channel |
Roles (8 tools)
| Tool | Description |
|---|---|
list_roles |
List all roles in a guild, sorted by position |
get_role |
Get detailed information about a specific role |
create_role |
Create a new role with optional name, color, hoist, mentionable, and permissions |
modify_role |
Modify an existing role's properties |
delete_role |
Permanently delete a role |
reorder_roles |
Reorder roles by specifying new positions |
add_role_to_member |
Add a role to a guild member |
remove_role_from_member |
Remove a role from a guild member |
Members and Moderation (10 tools)
| Tool | Description |
|---|---|
list_members |
List guild members with pagination (up to 1000 per request) |
search_members |
Search for members by username or nickname prefix |
get_member |
Get detailed info about a member (roles, join date, timeout status) |
modify_member |
Modify a member's nickname, roles, or voice mute/deafen status |
kick_member |
Remove a member from the guild (they can rejoin with an invite) |
ban_member |
Ban a user from the guild, optionally deleting recent messages (up to 7 days) |
unban_member |
Remove a ban, allowing the user to rejoin |
list_bans |
List all banned users with reasons |
get_ban |
Get ban information for a specific user |
timeout_member |
Temporarily prevent a member from interacting, or remove an existing timeout |
Composite Tools (5 tools)
| Tool | Description |
|---|---|
server_audit_snapshot |
Read-only snapshot of guild info, all channels, and all roles |
setup_channel_category |
Create a category with child channels and optional permission overwrites in one operation |
lockdown_channel |
Set a channel to read-only for @everyone, or restore it |
setup_role_hierarchy |
Create multiple roles with colors and permissions, then reorder them into a hierarchy |
bulk_assign_role |
Assign a role to multiple members at once, with per-member error reporting |
Development
bun run start # Start the server
bun run dev # Start with --watch for auto-reload
bun test # Run tests
bun run lint # Lint code (Biome)
bun run format # Format code (Biome)
Project Structure
src/
index.ts # Entry point — creates MCP server and stdio transport
config.ts # Environment variable loading and validation (Zod)
discord/
client.ts # Discord REST client with rate limiting and retry
rate-limiter.ts # Per-route bucket rate limiter
types.ts # Discord API type definitions
errors.ts # Discord API error handling
permissions.ts # Permission flag constants
tools/
index.ts # Tool registration coordinator
server-info.ts # Guild info tools
channels.ts # Channel management tools
roles.ts # Role management tools
members.ts # Member and moderation tools
composite.ts # Multi-step workflow tools
utils/
formatters.ts # Human-readable output formatting
validators.ts # Shared Zod validators (snowflake, color, permissions)
License
MIT
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。