mcp-client-discord
Listens for Discord @mentions and queues them for retrieval via MCP tools, enabling AI agents to process and respond to mentions in Discord channels.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-client-discordget my pending Discord mentions"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-client-discord
Discord Event Listener with Claude-Powered Auto-Response via KADI Broker.
Overview
mcp-client-discord is a TypeScript-based MCP server that listens for Discord @mentions and queues them for template-agent-typescript to process. It uses Discord Gateway to receive real-time events.
Related MCP server: Discord MCP Server
Architecture
Discord Channel → Gateway Event → Mention Queue → template-agent-typescript → Claude API → mcp-server-discord → Discord ReplyComponents
Discord Gateway: Real-time WebSocket connection for receiving events
Mention Queue: In-memory queue (max 100) of unprocessed @mentions
MCP Server: Exposes
get_discord_mentionstool for KADI broker integrationTool Registration: Available to any KADI agent via broker
Setup
1. Install Dependencies
npm install2. Configure Environment
Copy .env.example to .env:
cp .env.example .envEdit .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=info3. Get Discord Bot Token
Go to Discord Developer Portal
Create a new application
Go to "Bot" section
Click "Reset Token" and copy the token
Enable "Message Content Intent" in bot settings
Invite bot to your server with proper permissions (Send Messages, Read Messages, etc.)
4. Build
npm run build5. Run
Development mode (with hot-reload):
npm run devProduction mode:
npm startMCP Tools
get_discord_mentions
Retrieve pending Discord @mentions from the queue.
Input:
limit(optional): Maximum number of mentions to retrieve (1-50, default: 10)
Output:
{
"mentions": [
{
"id": "message_id",
"user": "user_id",
"username": "username",
"text": "message text without @bot mention",
"channel": "channel_id",
"channelName": "channel_name",
"guild": "guild_id",
"ts": "ISO_timestamp"
}
],
"count": 1,
"retrieved_at": "ISO_timestamp"
}Integration with KADI Broker
The MCP server is registered in kadi-broker/config/mcp-upstreams.json:
{
"id": "discord-client",
"name": "Discord Event Listener (mcp-client-discord)",
"type": "stdio",
"prefix": "discord_client",
"enabled": true,
"stdio": {
"command": "node",
"args": ["C:\\p4\\Personal\\SD\\mcp-client-discord\\dist\\index.js"],
"env": {
"DISCORD_TOKEN": "your_token",
"DISCORD_GUILD_ID": "your_guild_id"
}
},
"networks": ["discord"]
}Event Topics
Topic Pattern Standard
All KĀDI events follow the standardized topic pattern: {platform}.{event_type}.{bot_id}
{platform}: Platform identifier (slack,discord, etc.){event_type}: Event type (app_mention,mention, etc.){bot_id}: Bot unique identifier (critical for multi-bot deployments)
Why bot_id is required:
✅ Enables multiple bot instances in the same server
✅ Routes events only to the intended bot
✅ Prevents cross-bot event delivery
✅ Supports multi-tenant deployments
Validation: Topics are automatically validated by @agents/shared package. Invalid patterns will log warnings but still publish.
See TOPIC_PATTERN.md for complete documentation.
discord.mention.{BOT_USER_ID}
Published when the bot is @mentioned in Discord.
Event Payload (DiscordMentionEvent):
{
id: string; // Unique message ID
user: string; // Discord user ID who mentioned the bot
username: string; // Discord username
text: string; // Message text (with @bot mention removed)
channel: string; // Discord channel ID
channelName: string; // Discord channel name
guild: string; // Discord guild/server ID
ts: string; // ISO 8601 timestamp
timestamp: string; // ISO 8601 datetime when event was published
}Usage with Agent_TypeScript
Agent_TypeScript polls this MCP server for new @mentions:
// In Agent_TypeScript
const protocol = client.getBrokerProtocol();
const result = await protocol.invokeTool({
targetAgent: 'discord-client',
toolName: 'discord_client_get_discord_mentions',
toolInput: { limit: 5 },
timeout: 10000
});
const mentions = JSON.parse(result.content[0].text).mentions;Discord Bot Permissions
Required bot permissions:
View Channels
Send Messages
Read Message History
Add Reactions (optional)
Required Gateway Intents:
Guilds
Guild Messages
Message Content
Logging
The server logs to console with emoji indicators:
🚀 Startup messages
📬 Mention queued
📤 Mentions retrieved
✅ Success messages
❌ Error messages
💬 Received mention
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 permissions
Bot not responding to mentions
Verify "Message Content Intent" is enabled
Check bot has "Send Messages" permission
Ensure bot is not muted or blocked
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/a-g-e-n-t-s/mcp-client-discord'
If you have feedback or need assistance with the MCP directory API, please join our Discord server