mcp-discord-bridge

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.

Category
Visit Server

README

Discord MCP Server

npm version npm downloads CI License: MIT

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

  1. Go to the Discord Developer Portal
  2. Click New Application — give it a name
  3. Go to Bot tab — click Reset Token — copy and save the token somewhere safe

Step 2: Invite the Bot to Your Server

  1. In the Developer Portal, go to OAuth2 > URL Generator
  2. Check these scopes: bot, applications.commands
  3. Check these permissions: Send Messages, Read Message History, Manage Channels, Manage Roles, Manage Webhooks, Kick Members, Ban Members, Moderate Members, Manage Nicknames
  4. 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 .env file — it's already in .gitignore
  • Treat your DISCORD_TOKEN like 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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured