discord-selfbot-mcp
Comprehensive Discord selfbot MCP server with 80 tools for full user autonomy, including messaging, guild management, voice, interactions, and more.
README
⚠ DEPRECATED. Use discord.py-self-mcp instead!
<h1 align="center">discord-selfbot-mcp</h1>
<p align="center"> comprehensive discord selfbot mcp server with 80 tools for full user autonomy </p>
<p align="center"> <img src="https://img.shields.io/badge/license-MIT-green" alt="license"> <img src="https://img.shields.io/badge/language-typescript-blue" alt="language"> <img src="https://img.shields.io/badge/mcp-sdk-orange" alt="mcp"> </p>
installation
Codex
Tell Codex:
Fetch and follow instructions from https://raw.githubusercontent.com/Microck/discord-selfbot-mcp/refs/heads/master/.codex/INSTALL.md
OpenCode
Tell OpenCode:
Fetch and follow instructions from https://raw.githubusercontent.com/Microck/discord-selfbot-mcp/refs/heads/master/.opencode/INSTALL.md
manual installation
one-liner (recommended for AI terminals):
npx discord-selfbot-mcp-setup
how it works (step by step)
-
run the setup wizard
npx discord-selfbot-mcp-setup -
choose how to provide your token:
1= Extract automatically (opens browser, you log in)2= Enter token manually (paste your existing token)3= Show me how to get a token manually
-
choose your MCP client:
1= Claude Desktop (auto-configuresclaude_desktop_config.json)2= Cursor (auto-configures Cursor's MCP settings)3= OpenCode / Claude Code CLI (prints config JSON for you to paste)4= Generic (savesmcp.jsonto current directory)5= Just show me the config (no save)
-
restart your MCP client - the discord-selfbot tools are now available
no .env files needed - the token is stored directly in your MCP client's config.
getting your token manually
if you prefer not to use the browser extraction:
- open Discord in your browser (discord.com/app)
- log in to your account
- press F12 to open Developer Tools
- go to the Console tab
- paste this and press Enter:
(webpackChunkdiscord_app.push([[],{},e=>{m=[];for(let c in e.c)m.push(e.c[c])}]),m).find(m=>m?.exports?.default?.getToken).exports.default.getToken() - copy the token (without quotes)
- run
npx discord-selfbot-mcp-setupand choose option 2 to enter it
manual configuration
if you already have a token, add this to your MCP config:
claude desktop (claude_desktop_config.json):
{
"mcpServers": {
"discord-selfbot": {
"command": "npx",
"args": ["discord-selfbot-mcp"],
"env": {
"DISCORD_TOKEN": "your_token_here"
}
}
}
}
opencode/claude code (.opencode.json or project config):
{
"mcpServers": {
"discord-selfbot": {
"command": "npx",
"args": ["discord-selfbot-mcp"],
"env": {
"DISCORD_TOKEN": "your_token_here"
}
}
}
}
the token is passed via the env block in the MCP config - no separate .env file required.
captcha handling
when joining servers, discord sometimes requires captcha verification.
automatic solving (optional):
{
"mcpServers": {
"discord-selfbot": {
"command": "npx",
"args": ["discord-selfbot-mcp"],
"env": {
"DISCORD_TOKEN": "your_token",
"CAPTCHA_SERVICE": "capsolver",
"CAPTCHA_API_KEY": "your_api_key"
}
}
}
}
| service | env value | pricing | signup |
|---|---|---|---|
| CapSolver | capsolver |
~$0.80/1k | capsolver.com |
| CapMonster | capmonster |
~$0.70/1k | capmonster.cloud |
| NopeCHA | nopecha |
100 free/day | nopecha.com |
browser fallback (default):
if no captcha service is configured, the MCP automatically:
- opens a local webpage in your browser
- shows instructions: "click to open discord invite"
- you solve the captcha manually in your browser
- the MCP detects when you've joined and continues
this means captcha never blocks you - worst case you solve it yourself in ~10 seconds.
features
80 tools across 18 categories.
| category | tools | description |
|---|---|---|
| system | 3 | health, whoami, get_config |
| guilds | 8 | list, info, members, nickname, leave, invite, create, delete |
| channels | 5 | list, info, create, delete, edit |
| messages | 8 | read, send, reply, edit, delete, search, get, forward |
| reactions | 4 | react, unreact, get_reactions, remove_all |
| pins | 3 | pin, unpin, list_pinned |
| dms | 5 | list, read, send, create, close |
| threads | 7 | list, create, join, leave, archive, read, send |
| presence | 5 | set_status, set_custom, set_activity, clear, get_user |
| voice | 5 | join, leave, set_state, get_state, list_members |
| relationships | 8 | friends, blocked, pending, request, remove, block, unblock, accept |
| notifications | 5 | mentions, mark_read, mark_guild_read, mute_channel, mute_guild |
| files | 3 | upload, download, list |
| events | 4 | list, get, rsvp, create |
| profile | 1 | edit_profile (avatar, bio, username) |
| interactions | 4 | trigger_typing, click_button, select_menu, get_components |
| invites | 1 | accept_invite (auto browser fallback for captcha) |
| slash | 1 | send_slash (execute bot slash commands, waits for response) |
comparison
| feature | discord-selfbot-mcp | Maol-1997 | codebyyassine | elyxlz |
|---|---|---|---|---|
| read messages | yes | yes | yes | yes |
| send messages | yes | yes | yes | yes |
| list guilds | yes | yes | yes | yes |
| list channels | yes | yes | yes | yes |
| get user info | yes | yes | yes | no |
| search messages | yes | no | no | no |
| create channels | yes | no | yes | no |
| delete channels | yes | no | yes | no |
| edit messages | yes | no | no | no |
| delete messages | yes | no | no | no |
| join voice | yes | no | no | no |
| manage friends | yes | no | no | no |
| manage threads | yes | no | no | no |
| slash commands | yes | no | no | no |
| click buttons | yes | no | no | no |
| select menus | yes | no | no | no |
| setup wizard | yes | no | no | no |
| captcha fallback | yes | no | no | no |
| total tools | 80 | 7 | 29 | 4 |
examples
slash commands - execute bot commands:
send_slash({
channel_id: "123456789",
bot_id: "987654321",
command: "task import",
args: ["argument1", "argument2"]
})
button clicks - interact with bot messages:
click_button({
channel_id: "123456789",
message_id: "987654321",
button_id: "0,0" // row 0, col 0 (first button)
})
select menus - choose dropdown options:
select_menu({
channel_id: "123456789",
message_id: "987654321",
menu_id: "0",
values: ["option1", "option2"]
})
inspect components - see all buttons/menus on a message:
get_components({
channel_id: "123456789",
message_id: "987654321"
})
troubleshooting
| problem | solution |
|---|---|
| token invalid | run npx discord-selfbot-mcp-setup to extract a fresh one |
| rate limited | reduce RATE_LIMIT_CONCURRENCY env var (default: 3) |
| missing permissions | ensure account has access to the guild/channel |
| captcha required | configure captcha service OR just solve it in the browser popup |
| mcp not loading | restart your MCP client after config changes |
project structure
src/
├── core/ # configuration, logging, errors, captcha
├── discord/ # discord.js client wrapper
├── mcp/ # mcp server & registry
├── tools/ # 80 tool implementations
│ ├── channels/ # channel management
│ ├── dms/ # direct messages
│ ├── events/ # scheduled events
│ ├── files/ # file upload/download
│ ├── guilds/ # server management
│ ├── interactions/ # buttons, menus, typing
│ ├── invites/ # join servers (with captcha handling)
│ ├── messages/ # send, read, edit, delete, search
│ ├── notifications/ # mentions, mute, mark read
│ ├── presence/ # status, activity
│ ├── profile/ # edit avatar, bio, username
│ ├── relationships/ # friends, blocks
│ ├── slash/ # execute bot slash commands
│ ├── system/ # health, whoami
│ ├── threads/ # thread management
│ └── voice/ # join/leave voice channels
├── index.ts # entry point
└── setup.ts # setup wizard
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.