Fire in da houseTop Tip:Most people pay up to $340 per month for Perplexity, MidJourney, Runway, ChatGPT, and more - but you can get them all your AI tools for $15 with Galaxy. It's free to test!Fire in da houseCheck it out

discordmcp

MCP.Pizza Chef: v-3

discordmcp is an MCP server that integrates LLMs like Claude with Discord, allowing them to read and send messages in Discord channels via the Discord API. It supports automatic server and channel discovery, handles both channel names and IDs, and ensures proper error handling and validation. This server requires a Discord bot token and appropriate permissions, enabling secure, controlled interaction between LLMs and Discord environments.

Use This MCP server To

Send automated messages to Discord channels via LLMs Read recent Discord channel messages for context-aware responses Enable LLMs to participate in Discord conversations securely Automatically discover Discord servers and channels for interaction Validate and handle errors in Discord message operations Integrate Discord chat data into LLM workflows Use LLMs to moderate or summarize Discord channel discussions

README

Discord MCP Server

A Model Context Protocol (MCP) server that enables LLMs to interact with Discord channels, allowing them to send and read messages through Discord's API. Using this server, LLMs like Claude can directly interact with Discord channels while maintaining user control and security.

Features

  • Send messages to Discord channels
  • Read recent messages from channels
  • Automatic server and channel discovery
  • Support for both channel names and IDs
  • Proper error handling and validation

Prerequisites

  • Node.js 16.x or higher
  • A Discord bot token
  • The bot must be invited to your server with proper permissions:
    • Read Messages/View Channels
    • Send Messages
    • Read Message History

Setup

  1. Clone this repository:
git clone https://github.com/yourusername/discordmcp.git
cd discordmcp
  1. Install dependencies:
npm install
  1. Create a .env file in the root directory with your Discord bot token:
DISCORD_TOKEN=your_discord_bot_token_here
  1. Build the server:
npm run build

Usage with Claude for Desktop

  1. Open your Claude for Desktop configuration file:

    • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
    • Windows: %APPDATA%\Claude\claude_desktop_config.json
  2. Add the Discord MCP server configuration:

{
  "mcpServers": {
    "discord": {
      "command": "node",
      "args": ["path/to/discordmcp/build/index.js"],
      "env": {
        "DISCORD_TOKEN": "your_discord_bot_token_here"
      }
    }
  }
}
  1. Restart Claude for Desktop

Available Tools

send-message

Sends a message to a specified Discord channel.

Parameters:

  • server (optional): Server name or ID (required if bot is in multiple servers)
  • channel: Channel name (e.g., "general") or ID
  • message: Message content to send

Example:

{
  "channel": "general",
  "message": "Hello from MCP!"
}

read-messages

Reads recent messages from a specified Discord channel.

Parameters:

  • server (optional): Server name or ID (required if bot is in multiple servers)
  • channel: Channel name (e.g., "general") or ID
  • limit (optional): Number of messages to fetch (default: 50, max: 100)

Example:

{
  "channel": "general",
  "limit": 10
}

Development

  1. Install development dependencies:
npm install --save-dev typescript @types/node
  1. Start the server in development mode:
npm run dev

Testing

You can test the server using the MCP Inspector:

npx @modelcontextprotocol/inspector node build/index.js

Examples

Here are some example interactions you can try with Claude after setting up the Discord MCP server:

  1. "Can you read the last 5 messages from the general channel?"
  2. "Please send a message to the announcements channel saying 'Meeting starts in 10 minutes'"
  3. "What were the most recent messages in the development channel about the latest release?"

Claude will use the appropriate tools to interact with Discord while asking for your approval before sending any messages.

Security Considerations

  • The bot requires proper Discord permissions to function
  • All message sending operations require explicit user approval
  • Environment variables should be properly secured
  • Token should never be committed to version control
  • Channel access is limited to channels the bot has been given access to

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This project is licensed under the MIT License - see the LICENSE file for details.

Support

If you encounter any issues or have questions:

  1. Check the GitHub Issues section
  2. Consult the MCP documentation at https://modelcontextprotocol.io
  3. Open a new issue with detailed reproduction steps

discordmcp FAQ

What permissions does the Discord bot need?
The bot requires Read Messages/View Channels, Send Messages, and Read Message History permissions to function properly.
How do I set up the discordmcp server?
Clone the repository, install dependencies with npm, and configure your Discord bot token in a .env file.
Can discordmcp handle both channel names and IDs?
Yes, it supports interaction using both channel names and channel IDs for flexibility.
How does discordmcp ensure secure interaction with Discord?
It uses a Discord bot with scoped permissions and proper error handling to maintain user control and security.
Is discordmcp compatible with LLMs other than Claude?
While designed for Claude, it can work with other LLMs supporting MCP, such as OpenAI's GPT-4 and Anthropic's Claude.
What Node.js version is required to run discordmcp?
Node.js version 16.x or higher is required.
How does discordmcp handle errors during message sending or reading?
It includes proper error handling and validation to manage API errors and invalid inputs gracefully.