Discord MCP Server
Enables AI agents to send and receive Discord messages using a user's account to facilitate real-time testing and development of bot commands directly from an editor. It provides tools for listing guilds, managing messages, and monitoring bot responses within Discord channels.
README
Discord MCP Server for VS Code
An MCP (Model Context Protocol) server that lets VS Code Copilot (or any MCP-compatible agent) send and receive Discord messages as your own user account — enabling real-time testing of Discord bot commands directly from your editor.
⚠️ Discord ToS Notice: Automating a user account ("self-botting") is against Discord's Terms of Service. This tool is intended strictly for local development/testing of your own bots on your own servers. Do not use it for spam, abuse, or on servers you don't control. Use at your own risk.
Why a user account?
Many bot commands check server state tied to the command invoker — e.g., message.member.voice.channel to verify the user is in a voice channel before playing audio. A separate bot account cannot satisfy these checks. Messages must originate from your real Discord user to test these commands properly.
Prerequisites
- Node.js 18+ (uses native
fetch) - VS Code with GitHub Copilot (or another MCP host like Claude Desktop / Cursor)
- Your Discord user token (see below)
Obtaining your Discord user token
- Open Discord in a browser or the desktop app
- Open Developer Tools (
F12/Ctrl+Shift+I) - Go to the Network tab
- Perform any action in Discord (send a message, switch channels)
- Find any request to
discord.com/api - Copy the
Authorizationheader value — that's your user token
Your user token grants full access to your Discord account. Treat it like a password and never commit it to version control.
Installation
# 1. Clone the repository
git clone https://github.com/masonbesmer/code-discord-mcp.git
cd code-discord-mcp
# 2. Install dependencies
npm install
# 3. Build
npm run build
# 4. Set your Discord user token
cp .env.example .env
# Edit .env and set DISCORD_USER_TOKEN=your-token-here
VS Code Integration
The repository includes .vscode/mcp.json which automatically registers the server with VS Code. The server reads your token from the DISCORD_USER_TOKEN environment variable.
Make sure the variable is set in your shell before launching VS Code:
# macOS / Linux
export DISCORD_USER_TOKEN="your-token-here"
code .
# Windows PowerShell
$env:DISCORD_USER_TOKEN = "your-token-here"
code .
Available Tools
| Tool | Description |
|---|---|
send_message |
Send a text message to a Discord channel |
read_messages |
Read recent messages from a channel |
wait_for_response |
Send a command and wait for a bot response |
list_channels |
List channels in a guild |
list_guilds |
List guilds your account is in |
delete_message |
Delete a message (with confirmation prompt) |
Available Resources
| Resource | Description |
|---|---|
discord://guild/{guildId}/channels |
Channel list for a guild |
discord://channel/{channelId}/recent |
Last 25 messages in a channel |
Example Workflow
- Open your Discord bot project in VS Code
- Start a Copilot Chat session in Agent Mode
- Ask: "Send
!helpto my #bot-testing channel and show me what my bot responds with" - Copilot will:
- Call
list_guildsto find your server - Call
list_channelsto find#bot-testing - Call
wait_for_responsewith!help - Show you the bot's response inline in the chat
- Call
Development
# Watch mode (recompiles on file changes)
npm run dev
# Run tests
npm test
# Debug with MCP Inspector
npx @modelcontextprotocol/inspector node dist/index.js
Security
| Concern | Mitigation |
|---|---|
| Token exposure | Read from env var only; never logged or returned in responses; .env in .gitignore |
| Discord ToS | Local dev/testing on your own servers only |
| Rate limiting | Automatic retry after retry_after on HTTP 429; 500ms polling interval |
| Accidental pings | allowed_mentions: { parse: [] } prevents @everyone/@here pings |
| Destructive actions | delete_message has destructiveHint: true — VS Code shows a confirmation dialog |
| Stdout pollution | All diagnostic output goes to stderr; stdout is reserved for MCP JSON-RPC |
Dependencies
| Package | Purpose |
|---|---|
@modelcontextprotocol/sdk |
MCP server framework (stdio transport, tool registration) |
zod |
Input schema validation |
typescript (dev) |
TypeScript compiler |
@types/node (dev) |
Node.js type definitions |
vitest (dev) |
Test runner |
No Discord library needed. All Discord API calls use Node 18+ native
fetch.
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.