loading…
Search for a command to run...
loading…
Discord MCP server with 46 tools for channels, messages, forums, webhooks, members, roles, threads, and moderation. Zero-install via npx -y mcp-discord-bridge.
Discord MCP server with 46 tools for channels, messages, forums, webhooks, members, roles, threads, and moderation. Zero-install via npx -y mcp-discord-bridge. Also runs as a standalone bot with slash commands.
npm version npm downloads CI License: MIT
Control your Discord server using AI — 44 tools, no cloning required. Works with any MCP-compatible app: Claude Desktop, Cursor, Windsurf, Continue.dev, Zed, Claude Code, and more.
What is MCP? Model Context Protocol is an open standard that lets AI apps talk to external tools. This project is one of those tools — it gives any AI assistant the power to manage your Discord server.
npx -y mcp-discord-bridge
That's it — no clone, no npm install. Just add it to your AI app's MCP config (see Quick Start below).
Once connected, your AI assistant can:
It also runs as a standalone Discord bot with /ping, /info, and /serverinfo slash commands.
bot, applications.commandsSend Messages, Read Message History, Manage Channels, Manage Roles, Manage Webhooks, Kick Members, Ban Members, Moderate Members, Manage NicknamesAdd this to your app's MCP config — no cloning or installing needed:
{
"mcpServers": {
"discord": {
"command": "npx",
"args": ["-y", "mcp-discord-bridge"],
"env": {
"DISCORD_TOKEN": "paste_your_bot_token_here"
}
}
}
}
Where is the config file?
| App | Config Location |
|---|---|
| Claude Desktop | Windows: %APPDATA%\Claude\claude_desktop_config.json · macOS: ~/Library/Application Support/Claude/claude_desktop_config.json |
| Claude Code | ~/.claude.json (or run /mcp in Claude Code) |
| Cursor | Settings > search "MCP" > Edit MCP Settings |
| Windsurf | ~/.codeium/windsurf/mcp_settings.json |
| Continue.dev | ~/.continue/config.json |
| Zed | ~/.config/zed/settings.json |
Restart your AI app. You should now see Discord tools available. Try asking:
"List all channels in my Discord server"
| Tool | What It Does |
|---|---|
| Server | |
list_guilds |
List all servers the bot is in |
list_channels |
List all channels and categories |
| Channels | |
create_category |
Create a new category |
create_channel |
Create a text or voice channel |
delete_channel |
Delete a channel or category |
move_channel |
Move a channel to a different category |
rename_channel |
Rename a channel or category |
| Messages | |
get_channel_messages |
Fetch recent messages (up to 100) |
send_message |
Send a message to a channel |
delete_message |
Delete a message |
edit_message |
Edit a bot message |
search_messages |
Search messages by keyword |
send_dm |
Send a direct message to a user |
add_reaction |
Add an emoji reaction to a message |
remove_reaction |
Remove the bot's reaction from a message |
add_multiple_reactions |
Add multiple reactions at once |
| Forum Channels | |
list_forum_channels |
List all forum channels in a server |
create_forum_post |
Create a new forum post |
get_forum_post |
Fetch a forum post and its messages |
reply_to_forum_post |
Reply to a forum post |
delete_forum_post |
Delete a forum post |
| Webhooks | |
create_webhook |
Create a webhook for a channel |
send_webhook_message |
Send a message via webhook |
edit_webhook |
Edit a webhook |
delete_webhook |
Delete a webhook |
| Members | |
list_members |
List server members with roles |
get_member |
Get detailed info about a member |
| Roles | |
list_roles |
List all roles in a server |
assign_role |
Give a role to a member |
remove_role |
Take a role from a member |
create_role |
Create a new role with name, color, mentionable |
edit_role |
Edit a role's name or color |
delete_role |
Delete a role from the server |
| Moderation | |
kick_member |
Kick a member from the server |
ban_member |
Ban a user (with optional message cleanup) |
unban_member |
Unban a previously banned user |
timeout_member |
Timeout (mute) a member for a duration |
set_nickname |
Set or reset a member's nickname |
| Threads | |
create_thread |
Create a thread in a text channel |
list_threads |
List active and archived threads |
archive_thread |
Archive a thread (optionally lock it) |
unarchive_thread |
Unarchive a thread |
join_thread |
Make the bot join a thread |
delete_thread |
Delete a thread |
If you want to modify the code or run the standalone bot:
git clone https://github.com/iprashantraj/mcp-discord-bridge.git
cd mcp-discord-bridge
npm install
cp .env.example .env # fill in DISCORD_TOKEN, CLIENT_ID, GUILD_ID
Then use ts-node to run directly:
{
"mcpServers": {
"discord": {
"command": "npx",
"args": ["ts-node", "/full/path/to/mcp-discord-bridge/mcp-server.ts"],
"env": {
"DISCORD_TOKEN": "paste_your_bot_token_here"
}
}
}
}
If you just want the slash commands without MCP:
# Register commands (one time)
npm run deploy-commands
# Start the bot
npm run bot
| Command | Description |
|---|---|
/ping |
Check bot latency |
/info |
Show bot uptime and stats |
/serverinfo |
Show server details |
The image defaults to the MCP server (stdio). To run the standalone bot 24/7 instead, uncomment the command: ["node", "dist/index.js"] line in docker-compose.yml, then:
docker-compose up -d # Start in background
docker-compose logs -f # View logs
An MCP client talks to mcp-server.ts over stdio (JSON-RPC). The server advertises tools (with read-only/destructive annotations), then dispatches each call through mcp-handlers.ts — a 44-tool registry that validates args, checks bot permissions, and enforces read-only mode. Handlers act through the shared client from discord-client.ts, which owns login and connection state. The standalone bot (index.ts) is a separate entrypoint that reuses the same client factory.
Editable source: assets/architecture.excalidraw — open it at excalidraw.com.
npm run typecheck # Type check
npm run lint # Lint
npm run test # Run tests (59 tests)
npm run format # Format code
CI runs automatically on every push and PR via GitHub Actions.
mcp-discord-bridge/
├── discord-client.ts # Shared Discord client setup
├── mcp-server.ts # MCP server (tool schemas + wiring)
├── mcp-handlers.ts # Tool handler logic (registry pattern)
├── index.ts # Standalone bot (slash commands)
├── deploy-commands.ts # One-time command registration
├── tests/ # Vitest test suite
├── .github/workflows/ # CI pipeline
└── Dockerfile # Multi-stage Docker build
This server can delete channels, ban members, and remove roles. If you only want
the AI to read your server, set DISCORD_READONLY in the env block:
"env": {
"DISCORD_TOKEN": "your_token",
"DISCORD_READONLY": "true"
}
In read-only mode only the 10 read tools (list_*, get_*, search_messages)
are advertised and callable; every write/destructive tool is refused.
All tools also carry MCP annotations (readOnlyHint / destructiveHint), so
compatible clients can flag or confirm destructive actions before running them.
.env file — it's already in .gitignoreDISCORD_TOKEN like a password — if leaked, regenerate it immediately in the Developer PortalMIT — use it however you want.
Run in your terminal:
claude mcp add iprashantraj-mcp-discord-bridge -- npx Read, send and search emails from Claude
by GoogleSend, search and summarize Slack messages
by SlackNo-code MCP client for team chat platforms, such as Slack, Microsoft Teams, and Discord.
A community discord server dedicated to MCP by [Frank Fiegel](https://github.com/punkpeye)
Not sure what to pick?
Find your stack in 60 seconds
Author?
Embed badge for your README
Browse similar
All communication MCPs