dex-mcp
Debug and inspection tooling for Roblox projects, exposed as an MCP server so an AI agent can explore the instance tree, read/write properties, call remotes, and run Luau in a Roblox client driven by an executor.
README
dex-mcp
Debug and inspection tooling for Roblox projects, exposed as an MCP server so an AI agent can explore the instance tree, read/write properties, call remotes, and run Luau in a Roblox client driven by an executor.
Repository: https://github.com/972jesko/dex-mcp
Intended use: debugging, inspecting, and learning from your own Roblox projects locally. See GUIDELINES.md.
Install
npm install
npm run build
Run
node dist/index.js
On startup the server prints (to stderr) the local WebSocket URL and a shared token. The Luau bridge connects to that URL. Configure your MCP client to launch node /absolute/path/to/dist/index.js over stdio.
Configuration (environment variables)
| Variable | Default | Purpose |
|---|---|---|
DEX_MCP_HTTP |
false |
Remote mode. Bind 0.0.0.0, serve MCP over HTTP at /mcp, and point the bridge at wss://<host>. See Remote (hosted) mode. |
PORT |
— | Honoured before DEX_MCP_PORT (the var hosts like Railway inject). |
DEX_MCP_PORT |
8392 |
WebSocket hub port |
DEX_MCP_TOKEN |
auto-generated, persisted | Shared token required by the bridge. Generated once and saved (see DEX_MCP_TOKEN_FILE) so it stays stable across server restarts; set explicitly to pin it. Required in remote mode (container disks are ephemeral). |
DEX_MCP_TOKEN_FILE |
~/.dex-mcp/token |
Where the auto-generated token is persisted. |
DEX_MCP_ENABLE_WRITE |
true |
Enable set_property |
DEX_MCP_ENABLE_REMOTES |
true |
Enable remote calling/spying |
DEX_MCP_ENABLE_RUN_LUAU |
true |
Enable run_luau |
DEX_MCP_RPC_TIMEOUT_MS |
15000 |
Per-request timeout |
401 Unauthorized from the bridge? The bridge baked in a token from an earlier server start. With a persisted token this no longer happens on restart; if you still see it, the bridge chunk is stale — stop it in your executor and re-run the loader one-liner so it fetches the current token.
Remote (hosted) mode
By default dex-mcp is local-only: the MCP server talks to its client over stdio and the hub
binds 127.0.0.1, so the executor and the MCP client must share one machine. Remote mode lifts
that constraint — the same process binds 0.0.0.0, exposes the MCP server over Streamable HTTP
at /mcp, and serves the bridge a wss://<host> target — so a hosted instance (e.g. Railway) can
sit between an executor and a remote MCP client.
Enable it with two env vars on the host:
| Var | Value |
|---|---|
DEX_MCP_HTTP |
true |
DEX_MCP_TOKEN |
a fixed secret you choose (the disk is ephemeral, so pin it) |
PORT is injected by the platform and honoured automatically. Then:
- MCP client → point it at
https://<host>/mcp, authenticating with the token viaAuthorization: Bearer <token>(or?token=<token>). - Executor (Roblox side) →
loadstring(game:HttpGet("https://<host>/bridge?token=<token>"))(). In remote mode/bridgeis token-gated (the served chunk embeds the token, so a public/bridgewould leak it) and injectswss://<host>as the bridge's connect target. GET /healthreturns200for the platform healthcheck.
⚠️ Security.
/mcpruns arbitrary Luau (run_luau), writes properties, and fires remotes in the connected client. In remote mode that capability is reachable over the public internet, gated only by the shared token. Use a long randomDEX_MCP_TOKEN, and only against a game you own.
The bridge (Roblox side)
The Luau bridge runs inside a script executor and connects back to this server.
- Start the server:
node dist/index.js. It prints a loader line. - In your executor (in a game you own / are allowed to inspect), run:
The server injects the per-run auth token into the served script automatically.loadstring(game:HttpGet("http://127.0.0.1:<port>/bridge"))() - The bridge connects over WebSocket and answers the MCP tools. It auto-reconnects if the server restarts.
The bridge is assembled on the fly from bridge/codec.luau, bridge/core.luau, and bridge/dex-bridge.luau. The codec and core are unit-tested with lune: npm run test:bridge.
Executor requirements
WebSocket.connect(UNC/sUNC standard).loadstringforrun_luau.hookmetamethod/getrawmetatable/getnamecallmethod/newcclosurefor the remote spy (capability-gated — the bridge degrades gracefully without them).
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.