codex-discord-mcp
A local-first Discord bridge for Codex CLI, enabling Discord-to-Codex relay, Codex-to-Discord MCP tools, and hybrid workflows with access control and attachment safety.
README
codex-discord-mcp
A local-first Discord bridge for Codex CLI.
Use it in three ways:
- Discord -> Codex: mention or DM your bot, run
codex exec --json, and post the final answer back to Discord. - Codex -> Discord: expose Discord tools to Codex through MCP, including
reply,fetch_messages,react,edit_message,download_attachment, andlatest_generated_images. - Hybrid workflow: receive Discord messages into a local queue, then let Codex inspect and respond through MCP tools.
This is not an official OpenAI plugin. It is a local bridge designed around Codex CLI, MCP, and Discord bot APIs.
Which Mode Should I Use?
| Goal | Use |
|---|---|
| DM Codex from Discord | bot mode |
| Let Codex send Discord replies | mcp mode |
| Let Codex read recent Discord messages | mcp mode |
| Queue Discord messages for Codex to inspect | mcp mode with list_pending_messages |
| Fully automatic Discord -> Codex -> Discord | bot mode |
Security Model
This bridge treats Discord as untrusted input.
Discord users cannot:
- approve pairings
- allow users
- allow channels
- change bridge policy
- read bridge state files
- bypass Codex sandbox or approval settings
Only local terminal commands can change access policy. MCP tools can read and reply through allowlisted Discord channels, but they cannot modify the allowlist or approve pairings.
Default safety posture:
- Default sandbox:
read-only - Default approval policy:
never, becausebotmode is non-interactive - Recommended first run:
read-only - Use
workspace-writeonly in an isolated repository or disposable worktree - Never use
danger-full-accessfor a public Discord channel
When bot mode starts with CODEX_SANDBOX=workspace-write or CODEX_SANDBOX=danger-full-access and CODEX_APPROVAL_POLICY=never, the bridge prints a runtime warning. Set CODEX_DISCORD_ASSUME_YES=true to suppress the warning in controlled automation.
Requirements
- Node.js 20 or newer.
- Codex CLI installed and authenticated for
botmode. - A Discord application with a bot token.
- Discord bot privileged Message Content Intent enabled.
Install
Global install:
npm install -g codex-discord-mcp
codex-discord-mcp doctor
codex-discord-mcp init
Run through npx without a global install:
npx -y codex-discord-mcp doctor
Local development install:
npm install
npm run build
node ./dist/cli.js --help
Discord Bot Setup
- Create a Discord application in the Discord Developer Portal.
- Add a bot and copy its token.
- Enable Message Content Intent for the bot.
- Invite the bot to a server if you want guild channels.
Useful bot permissions:
- View Channels
- Send Messages
- Send Messages in Threads
- Read Message History
- Attach Files
- Add Reactions
Print an invite URL:
codex-discord-mcp invite-url <client-id>
Store the token locally:
codex-discord-mcp configure
The token is written to ~/.codex/discord/.env by default. Override the state directory with CODEX_DISCORD_STATE_DIR.
You can also read the token from an existing environment variable:
codex-discord-mcp configure --token-env DISCORD_BOT_TOKEN
Quick Start
Interactive setup:
codex-discord-mcp init
Check local configuration:
codex-discord-mcp doctor
codex-discord-mcp doctor --json
Mode 1: Discord To Codex Relay
Run:
codex-discord-mcp bot
Default behavior:
- Unknown DM users receive a one-hour pairing code.
- Pair locally with
codex-discord-mcp access pair <code>. - After pairing, each DM message triggers
codex exec --json. - The final Codex message is posted as a Discord reply.
Useful environment variables:
export CODEX_WORKDIR="/path/to/repo"
export CODEX_SANDBOX="read-only"
export CODEX_APPROVAL_POLICY="never"
export CODEX_RESUME_BY_CHANNEL="true"
codex-discord-mcp bot
For unattended relay mode, keep CODEX_APPROVAL_POLICY=never and use the least permissive sandbox that fits the channel.
Mode 2: Codex MCP Tools
Print a local config snippet:
codex-discord-mcp print-config
Print an npx based config snippet:
codex-discord-mcp print-config --npx
Add the snippet to ~/.codex/config.toml or a trusted project .codex/config.toml. A typical npx config looks like:
[mcp_servers.discord]
command = "npx"
args = ["-y", "codex-discord-mcp", "mcp"]
startup_timeout_sec = 20
tool_timeout_sec = 60
Then start Codex and run /mcp to confirm the Discord tools are loaded.
Available MCP tools:
| Tool | Risk | Notes |
|---|---|---|
fetch_messages |
Low | Reads recent allowlisted channel history |
list_pending_messages |
Low | Reads local queue entries |
bridge_status |
Low | Reads local bridge status |
react |
Low | Adds a reaction |
reply |
Medium | Sends a Discord message |
send_message |
Medium | Sends a Discord message |
edit_message |
Medium | Edits a message previously sent by the bot |
download_attachment |
Medium | Downloads Discord attachments into the local inbox |
latest_generated_images |
Low | Returns absolute paths of the newest images from Codex's image_gen output dir |
mark_message_handled |
Medium | Mutates local queue state |
Access Control
Access is managed by local CLI commands, not MCP tools.
codex-discord-mcp access show
codex-discord-mcp access policy allowlist
codex-discord-mcp access allow-user 123456789012345678
codex-discord-mcp access allow-channel 234567890123456789
codex-discord-mcp access allow-channel 234567890123456789 --no-mention
DM policy values:
pairing: unknown DM users get a one-hour pairing code. This is the default.allowlist: unknown DM users are silently ignored.disabled: all DMs are ignored.
Guild channels are opt-in by channel ID. By default, the bot only responds in an allowed guild channel when it is mentioned or when the user replies to a recent bot message. Use --no-mention only for dedicated bot channels.
Attachment Safety
The bridge refuses to attach its own state files, except files downloaded into the inbox. It also blocks attachment paths outside the configured attachment roots.
Attachment uploads are restricted by default to:
- the bridge process working directory
CODEX_WORKDIR- the bridge inbox
- Codex's built-in
image_genoutput directory (~/.codex/generated_images, orCODEX_DISCORD_GENERATED_IMAGES_DIR)
The image_gen output directory is always allowed so generated images can be
attached. Call latest_generated_images to get the absolute path of the image
you just generated, then pass it in the files array of reply/send_message.
To allow generated files from other roots, set CODEX_DISCORD_ATTACHMENT_ROOTS using your platform path delimiter:
export CODEX_DISCORD_ATTACHMENT_ROOTS="/path/to/repo:/path/to/exports"
On Windows PowerShell:
$env:CODEX_DISCORD_ATTACHMENT_ROOTS="C:\path\to\repo;C:\path\to\exports"
Configuration Reference
| Variable | Default | Meaning |
|---|---|---|
DISCORD_BOT_TOKEN |
required | Discord bot token |
CODEX_DISCORD_STATE_DIR |
~/.codex/discord |
Bridge state directory |
CODEX_COMMAND |
codex |
Codex executable |
CODEX_WORKDIR |
process cwd | Working directory for Codex |
CODEX_SANDBOX |
read-only |
Codex sandbox mode |
CODEX_APPROVAL_POLICY |
never |
Codex approval policy for non-interactive bot mode |
CODEX_MODEL |
unset | Override Codex model |
CODEX_PROFILE |
unset | Use a Codex profile |
CODEX_RESUME_BY_CHANNEL |
false |
Resume one Codex thread per Discord channel |
CODEX_TIMEOUT_MS |
900000 |
Codex process timeout in milliseconds |
CODEX_EXTRA_ARGS |
unset | Extra arguments passed to Codex |
CODEX_SKIP_GIT_REPO_CHECK |
true |
Pass --skip-git-repo-check to codex exec |
CODEX_DISCORD_ATTACHMENT_ROOTS |
cwd, workdir, inbox | Allowed outbound file roots |
CODEX_DISCORD_GENERATED_IMAGES_DIR |
~/.codex/generated_images |
Codex image_gen output dir surfaced by latest_generated_images and always allowed for attachments |
CODEX_DISCORD_ASSUME_YES |
false |
Suppress writable unattended bot warning |
Troubleshooting
codex-discord-mcp doctor
codex-discord-mcp access show
If the bot receives empty message content, enable Message Content Intent in the Discord Developer Portal.
If bot mode cannot launch Codex, set CODEX_COMMAND to the full executable path or run the bridge from the same shell where codex exec "hello" works.
If MCP tools do not appear, run:
codex-discord-mcp print-config --npx
Then add the printed snippet to Codex config and restart Codex.
Development
npm install
npm run typecheck
npm test
npm run build
Development commands:
npm run dev:mcp
npm run dev:bot
Release
The package is prepared for npm publishing with:
binentry:codex-discord-mcpfileswhitelist for published package contentsprepublishOnlyvalidation: typecheck, tests, build- Linux and Windows GitHub Actions CI
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.