Discord MCP Agent
A Model Context Protocol (MCP) server for Discord-based AI agent-user communication. Enables AI agents to communicate with users through Discord instead of IDE chat interfaces.
Installation
npx discord-mcp-agentAsk AI about Discord MCP Agent
Powered by Claude ยท Grounded in docs
I know everything about Discord MCP Agent. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
Discord MCP Agent
A Model Context Protocol (MCP) server for Discord-based AI agent-user communication. Enables AI agents to communicate with users through Discord instead of IDE chat interfaces.
Table of Contents
- Quick Start
- Discord Bot Setup
- Tools Reference
- Reaction Features
- Configuration
- Usage Examples
- Troubleshooting
- Requirements
- Contributing
- Links
Quick Start
Installation
# Using uvx (recommended - no install needed)
uvx discord-mcp-agent
# Or install via pip
pip install discord-mcp-agent
# For screenshot support
pip install discord-mcp-agent[screenshot]
VS Code / GitHub Copilot
Add to .vscode/mcp.json:
{
"servers": {
"discord": {
"type": "stdio",
"command": "uvx",
"args": ["discord-mcp-agent"],
"env": {
"DISCORD_TOKEN": "your-bot-token",
"DISCORD_GUILD_ID": "your-server-id",
"DISCORD_CHANNEL": "general"
}
}
}
}
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"discord": {
"command": "uvx",
"args": ["discord-mcp-agent"],
"env": {
"DISCORD_TOKEN": "your-bot-token",
"DISCORD_GUILD_ID": "your-server-id",
"DISCORD_CHANNEL": "general"
}
}
}
}
Discord Bot Setup
- Go to Discord Developer Portal
- Click New Application โ Give it a name โ Create
- Go to Bot section โ Click Add Bot
- Copy the Bot Token (keep this secret!)
- Enable under Privileged Gateway Intents:
- โ Message Content Intent
- Go to OAuth2 โ URL Generator:
- Scopes:
bot - Bot Permissions:
Send Messages,Read Message History,Add Reactions,Attach Files
- Scopes:
- Copy the generated URL and open it to invite the bot to your server
- Get your Server ID: Enable Developer Mode in Discord settings, right-click your server โ Copy ID
โ ๏ธ Security Warning: Never commit your bot token to version control! Use environment variables or
.envfiles.
Tools Reference
discord_ask
Send a question and wait for user response. Supports reaction-based interactions.
| Parameter | Type | Required | Description |
|---|---|---|---|
question | string | โ | The question to ask user |
Reactions automatically added:
- ๐ท Take screenshot
- โ Cancel request
Response format:
{
"text": "User's response text",
"attachments": [{ "filename": "...", "url": "..." }],
"cancelled": false
}
discord_notify
Send a notification (no response expected).
| Parameter | Type | Required | Description |
|---|---|---|---|
message | string | โ | The message to send |
discord_send_file
Send a file to the user.
| Parameter | Type | Required | Description |
|---|---|---|---|
file_path | string | โ | Absolute path to the file |
message | string | โ | Optional message with the file |
discord_screenshot
Take and send a desktop screenshot.
| Parameter | Type | Required | Description |
|---|---|---|---|
message | string | โ | Optional message with the screenshot |
Requires
pip install discord-mcp-agent[screenshot]
discord_embed
Send a rich embed message with full formatting.
| Parameter | Type | Required | Description |
|---|---|---|---|
title | string | โ | Embed title |
description | string | โ | Main content |
color | integer | โ | Hex color (default: 0x5865F2) |
fields | array | โ | Array of {name, value, inline} objects |
footer | string | โ | Footer text |
thumbnail_url | string | โ | Small image (top-right) |
image_url | string | โ | Large image (bottom) |
author_name | string | โ | Author name (top) |
url | string | โ | Title link URL |
Reaction Features
Every message from the bot includes interactive reaction buttons:
| Emoji | Action | Description |
|---|---|---|
| ๐ท | Screenshot | Takes a screenshot and sends it to Discord |
| โ | Cancel | Cancels the current discord_ask and returns control |
| โณ | Timeout | Added automatically when a request times out |
How It Works
- Bot sends a message with ๐ท and โ reactions
- User can click reactions to trigger actions
- ๐ท immediately captures and sends a screenshot
- โ cancels waiting and returns
"cancelled": true
Configuration
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
DISCORD_TOKEN | โ | - | Your Discord bot token |
DISCORD_GUILD_ID | โ | - | Your Discord server ID |
DISCORD_CHANNEL | โ | general | Channel name to use |
DISCORD_REMINDER | โ | - | Custom text appended to all responses |
DISCORD_ASK_TIMEOUT | โ | 300 | Seconds to wait for user response |
DISCORD_HTTP_TIMEOUT | โ | 30 | Seconds for HTTP operations |
DISCORD_CONNECTION_TIMEOUT | โ | 30 | Seconds to establish connection |
Custom Reminder
Inject custom instructions into every tool response:
{
"env": {
"DISCORD_REMINDER": "Remember: Always confirm with the user before completing tasks."
}
}
Timeout Configuration
Adjust timeouts for your use case:
{
"env": {
"DISCORD_ASK_TIMEOUT": "600",
"DISCORD_HTTP_TIMEOUT": "60"
}
}
Usage Examples
MCP Tool Call: Ask Question
{
"name": "discord_ask",
"arguments": {
"question": "What color theme would you like for the dashboard?"
}
}
Response:
{
"text": "I'd prefer a dark theme with blue accents",
"attachments": [],
"cancelled": false
}
MCP Tool Call: Send Embed
{
"name": "discord_embed",
"arguments": {
"title": "Build Complete โ
",
"description": "Your project has been successfully built.",
"color": 5763719,
"fields": [
{ "name": "Duration", "value": "2m 34s", "inline": true },
{ "name": "Size", "value": "1.2 MB", "inline": true }
],
"footer": "Built with discord-mcp-agent"
}
}
Handling Image Attachments
When users send images in response to discord_ask, they're automatically:
- Downloaded from Discord
- Encoded as base64
- Returned as
ImageContentfor AI model consumption
Troubleshooting
| Error | Cause | Solution |
|---|---|---|
DISCORD_TOKEN environment variable is required | Missing token | Set DISCORD_TOKEN in your MCP config |
Guild with ID X not found | Bot not in server | Invite bot using OAuth2 URL |
Channel 'X' not found in guild | Wrong channel name | Check DISCORD_CHANNEL matches exactly |
Failed to connect within 30 seconds | Network/token issue | Verify token and network connectivity |
PIL not installed | Screenshot dep missing | Run pip install discord-mcp-agent[screenshot] |
โณ No response received within X seconds | User didn't respond | Increase DISCORD_ASK_TIMEOUT or user can click โ |
Common Issues
Bot appears offline:
- Ensure
Message Content Intentis enabled in Discord Developer Portal - Check that the bot token is correct
Bot can't see messages:
- Enable
Message Content Intentin bot settings - Ensure bot has
Read Message Historypermission
Screenshots not working:
- Install Pillow:
pip install discord-mcp-agent[screenshot] - On Linux, may require display server access
Requirements
- Python 3.10+
mcp >= 1.0.0discord.py >= 2.0.0pydantic >= 2.0.0aiohttp >= 3.8.0Pillow >= 10.0.0(optional, for screenshots)
Security
โ ๏ธ Never commit your Discord bot token to version control!
- Use environment variables or
.envfiles - Add
.envto.gitignore - Regenerate token immediately if exposed
Contributing
Contributions are welcome!
- Fork the repository
- Create your feature branch
- Add tests for new features
- Submit a pull request
Development Setup
git clone https://github.com/zebbern/discord-mcp-agent.git
cd discord-mcp-agent
pip install -e ".[dev]"
pytest tests/ -v
Links
- ๐ฆ PyPI Package
- ๐ GitHub Repository
- ๐ Model Context Protocol
- ๐ฎ Discord Developer Portal
Made with โค๏ธ for the MCP community
