MCP_Discord_Server
Discord Message Sending Service for Claude Desktop and KADI Agents that enables sending messages and replies to Discord channels via the Discord REST API.
README
MCP_Discord_Server
Discord Message Sending Service for Claude Desktop and KADI Agents.
Overview
MCP_Discord_Server is a TypeScript-based MCP server that provides Discord message sending capabilities. It exposes tools for sending messages and replies via Discord REST API, making it accessible to Claude Desktop and any KADI agent through the broker.
Architecture
Claude Desktop / KADI Agent → kadi-broker → MCP_Discord_Server → Discord REST API → Discord Channel
Components
- Discord REST Client: Uses discord.js for Discord API integration
- Channel Resolution: Converts channel names to IDs automatically
- MCP Server: Exposes
send_messageandsend_replytools - Stateless Design: No event listening, pure message sending
Setup
1. Install Dependencies
npm install
2. Configure Environment
Copy .env.example to .env:
cp .env.example .env
Edit .env with your Discord bot token:
DISCORD_TOKEN=your_discord_bot_token_here
DISCORD_GUILD_ID=your_discord_guild_id_here # Optional
MCP_LOG_LEVEL=info
3. Get Discord Bot Token
- Go to Discord Developer Portal
- Create a new application
- Go to "Bot" section
- Click "Reset Token" and copy the token
- Invite bot to your server with proper permissions (Send Messages, Read Messages, etc.)
4. Build
npm run build
5. Run
Development mode (with hot-reload):
npm run dev
Production mode:
npm start
MCP Tools
send_message
Send a message to a Discord channel.
Input:
channel(string): Channel ID or name (e.g., "general", "1234567890")text(string): Message text to sendmessage_id(optional string): Message ID to reply to
Output:
{
"success": true,
"message": "Message sent successfully",
"messageId": "1234567890",
"channelId": "9876543210"
}
send_reply
Reply to a specific message in a Discord channel.
Input:
channel(string): Channel ID where the message existsmessage_id(string): Message ID to reply totext(string): Reply message text
Output:
{
"success": true,
"message": "Reply sent successfully",
"messageId": "1234567891",
"channelId": "9876543210",
"replyTo": "1234567890"
}
Integration with KADI Broker
The MCP server is registered in kadi-broker/config/mcp-upstreams.json:
{
"id": "discord-server",
"name": "Discord Message Sender (MCP_Discord_Server)",
"type": "stdio",
"prefix": "discord_server",
"enabled": true,
"stdio": {
"command": "node",
"args": ["C:\\p4\\Personal\\SD\\MCP_Discord_Server\\dist\\index.js"],
"env": {
"DISCORD_TOKEN": "your_token",
"DISCORD_GUILD_ID": "your_guild_id"
}
},
"networks": ["discord"]
}
Usage Examples
From Agent_TypeScript
const protocol = client.getBrokerProtocol();
const result = await protocol.invokeTool({
targetAgent: 'discord-server',
toolName: 'discord_server_send_message',
toolInput: {
channel: 'general',
text: 'Hello from Agent_TypeScript!'
},
timeout: 10000
});
From Claude Desktop
When configured in Claude Desktop's MCP settings, you can simply ask:
"Send a message to the Discord channel #general saying 'Hello world!'"
Claude will call the send_message tool automatically.
Discord Bot Permissions
Required bot permissions:
- View Channels
- Send Messages
- Read Message History
Required Gateway Intents:
- Guilds
- Guild Messages
Channel Name Resolution
The server automatically resolves channel names to IDs:
"general"→"1234567890"(channel ID)"#announcements"→"9876543210"(strips # prefix)"1234567890"→"1234567890"(already an ID, passed through)
Channel cache is maintained in memory for fast resolution.
Logging
The server logs to console with emoji indicators:
- 🚀 Startup messages
- ✅ Message sent successfully
- ❌ Error messages
- 📤 Awaiting requests
Troubleshooting
"Discord client not ready after timeout"
- Check DISCORD_TOKEN is valid
- Verify bot has been invited to server
- Ensure internet connection is stable
"Channel not found" errors
- Verify bot has access to the channel
- Check channel name spelling
- Verify channel exists in the guild
"Failed to send message" errors
- Check bot has "Send Messages" permission in the channel
- Verify bot is not muted or has role restrictions
- Check message content doesn't violate Discord ToS
License
MIT
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.