MCP_Discord_Server

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.

Category
Visit Server

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_message and send_reply tools
  • 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

  1. Go to Discord Developer Portal
  2. Create a new application
  3. Go to "Bot" section
  4. Click "Reset Token" and copy the token
  5. 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 send
  • message_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 exists
  • message_id (string): Message ID to reply to
  • text (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

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