Interact with Discord directly from Claude Code sessions.
Discord MCP Server
A Python MCP (Model Context Protocol) server that lets you interact with Discord directly from Claude Code sessions. Send messages, read channels, post rich embeds, and list server channels — all through natural conversation with Claude.
Prerequisites
- Docker and Docker Compose installed
- Claude Code CLI installed
- A Discord bot token (setup guide below)
Discord Bot Setup
- Go to the Discord Developer Portal
- Click New Application, give it a name, and create it
- Go to Bot in the left sidebar
- Click Reset Token and copy the token — this is your
DISCORD_BOT_TOKEN - Under Privileged Gateway Intents, enable Message Content Intent
- Go to OAuth2 > URL Generator in the left sidebar
- Select scopes:
bot - Select bot permissions:
Send Messages,Read Message History,View Channels - Copy the generated URL and open it in your browser to invite the bot to your server
Installation
1. Clone the repository
git clone <your-repo-url>
cd discord-mcp-server
2. Set up environment variables
cp .env.example .env
# Edit .env and add your DISCORD_BOT_TOKEN and optionally DISCORD_DEFAULT_GUILD_ID
3. Build the Docker image
docker compose build
4. Register with Claude Code
Add the following to your Claude Code MCP settings. You can configure this in
~/.claude/settings.json (global) or .mcp.json (project-level):
{
"mcpServers": {
"discord-mcp": {
"command": "docker",
"args": [
"compose",
"-f", "/absolute/path/to/discord-mcp-server/docker-compose.yml",
"run", "--rm", "-i", "discord-mcp"
],
"env": {
"DISCORD_BOT_TOKEN": "your-bot-token-here",
"DISCORD_DEFAULT_GUILD_ID": "your-guild-id-here"
}
}
}
}
Note: Replace
/absolute/path/to/discord-mcp-serverwith the actual absolute path to this project on your machine. Replace the token and guild ID with your actual values.
Usage Examples
Once configured, you can use these tools in any Claude Code session:
List channels in a server:
"Show me all the channels in my Discord server"
Send a message:
"Send 'Deployment complete!' to the #general channel"
Read recent messages:
"What are the last 5 messages in #random?"
Send a rich embed:
"Send an embed to #updates with title 'Release v2.0' and a green color, with fields for 'Changes' and 'Breaking Changes'"
Tool Reference
discord_list_channels
Lists all text channels in a Discord server.
| Parameter | Type | Required | Description |
|---|---|---|---|
guild_id |
string | Yes | Discord server/guild ID |
discord_send_message
Sends a plain text message to a channel.
| Parameter | Type | Required | Description |
|---|---|---|---|
channel |
string | Yes | Channel ID or name (e.g. "general") |
content |
string | Yes | Message text (max 2000 chars) |
guild_id |
string | No | Server ID. Required if channel is a name and no default is set. |
discord_read_messages
Reads recent messages from a channel.
| Parameter | Type | Required | Description |
|---|---|---|---|
channel |
string | Yes | Channel ID or name |
guild_id |
string | No | Server ID. Required if channel is a name and no default is set. |
limit |
integer | No | Number of messages (default: 10, max: 50) |
discord_send_embed
Sends a rich embed message to a channel.
| Parameter | Type | Required | Description |
|---|---|---|---|
channel |
string | Yes | Channel ID or name |
title |
string | Yes | Embed title (max 256 chars) |
description |
string | No | Embed body text (max 4096 chars) |
color |
integer | No | Color as decimal (e.g. 3447003 for blue) |
fields |
list | No | List of {name, value, inline} objects (max 25 fields) |
content |
string | No | Plain text alongside the embed |
guild_id |
string | No | Server ID. Required if channel is a name and no default is set. |
Environment Variables
| Variable | Required | Description |
|---|---|---|
DISCORD_BOT_TOKEN |
Yes | Bot token from Discord Developer Portal |
DISCORD_DEFAULT_GUILD_ID |
No | Default server ID for all tool calls |
Architecture
Claude Code ←stdio→ MCP Server (Python) ←HTTPS→ Discord API v10
src/discord_mcp/types.py— Pydantic models with Discord API limit validation (Channel, Message, SendResult, Embed)src/discord_mcp/discord_client.py— Async Discord REST API wrapper using httpxsrc/discord_mcp/server.py— MCP tool definitions and handler functions
Key design decisions:
- All Discord API interaction goes through
DiscordClient— never call httpx directly from server.py - Tool handlers are separated from `@mcp
Tools (4)
discord_list_channelsLists all text channels in a Discord server.discord_send_messageSends a plain text message to a channel.discord_read_messagesReads recent messages from a channel.discord_send_embedSends a rich embed message to a channel.Environment Variables
DISCORD_BOT_TOKENrequiredBot token from Discord Developer PortalDISCORD_DEFAULT_GUILD_IDDefault server ID for all tool callsConfiguration
{"mcpServers": {"discord-mcp": {"command": "docker", "args": ["compose", "-f", "/absolute/path/to/discord-mcp-server/docker-compose.yml", "run", "--rm", "-i", "discord-mcp"], "env": {"DISCORD_BOT_TOKEN": "your-bot-token-here", "DISCORD_DEFAULT_GUILD_ID": "your-guild-id-here"}}}}