mcp-discord-bridge
MCP server that lets AI assistants control Discord servers 46 tools for channels, messages, forums, webhooks, roles, threads, and moderation. Install via npx -y mcp-discord-bridge with no clone required.
README
Discord MCP Server
Control your Discord server using AI — 46 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.
<p align="center"> <img src="./assets/demo.svg" alt="Demo showing Discord MCP tools in action" width="820"> </p>
Install in one line
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).
What Can It Do?
Once connected, your AI assistant can:
- Channels — create, delete, rename, move channels and categories
- Messages — read, send, edit, delete, search messages, send DMs, add/remove reactions
- Forum Channels — list forums, create/read/reply/delete forum posts
- Webhooks — create, send via, edit, and delete webhooks
- Members — list members, view profiles, check roles
- Roles — list, create, edit, delete, assign, and remove roles
- Moderation — kick, ban, unban, timeout members, set nicknames
- Threads — create, list, archive, unarchive, join, and delete threads
- Server — list all servers the bot is in, view channel layouts
It also runs as a standalone Discord bot with /ping, /info, and /serverinfo slash commands.
Quick Start (3 minutes)
Step 1: Create a Discord Bot
- Go to the Discord Developer Portal
- Click New Application — give it a name
- Go to Bot tab — click Reset Token — copy and save the token somewhere safe
Step 2: Invite the Bot to Your Server
- In the Developer Portal, go to OAuth2 > URL Generator
- Check these scopes:
bot,applications.commands - Check these permissions:
Send Messages,Read Message History,Manage Channels,Manage Roles,Manage Webhooks,Kick Members,Ban Members,Moderate Members,Manage Nicknames - Open the generated URL — select your server — authorize
Step 3: Add to Your AI App
Add 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 |
Step 4: Done!
Restart your AI app. You should now see Discord tools available. Try asking:
"List all channels in my Discord server"
All Available Tools (46)
| 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 |
Install from Source (for contributors)
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"
}
}
}
}
Running as a Standalone Bot
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 |
Docker Deployment
The image defaults to the MCP server (stdio). To run the standalone bot 24/7 instead, uncomment the command: npm run bot line in docker-compose.yml, then:
docker-compose up -d # Start in background
docker-compose logs -f # View logs
Development
npm run typecheck # Type check
npm run lint # Lint
npm run test # Run tests (53 tests)
npm run format # Format code
CI runs automatically on every push and PR via GitHub Actions.
Project Structure
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
Security
- Never commit your
.envfile — it's already in.gitignore - Treat your
DISCORD_TOKENlike a password — if leaked, regenerate it immediately in the Developer Portal - The bot can only assign roles below its own role in the hierarchy (Discord enforces this)
License
MIT — use it however you want.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.