UEMCP
Enables Claude to control Unreal Engine 5 editor, spawn actors, build materials, author Blueprints, and more, with zero plugin installation.
README
UEMCP
Drive Unreal Engine 5 with Claude. Nothing to install inside Unreal.
UEMCP is an open source MCP server by ATDev that connects Claude (Claude Code, Claude Desktop, or any MCP client) to a live Unreal Engine 5 editor. Spawn actors, build materials, author Blueprints, manage assets, fly the viewport camera, take screenshots, and run arbitrary editor Python, all from a conversation.
Why this one is different
Most Unreal MCP servers ship a C++ plugin you have to copy into your project and compile. UEMCP speaks Unreal's built-in Python remote execution protocol instead: the same multicast discovery and TCP command channel that ships with every copy of the engine. That means:
- Zero install on the Unreal side. No plugin to build, no project files to modify, no engine version matrix to chase.
- Works with vanilla UE 5.0 through 5.6, including Epic Games Launcher builds.
- Structured results, not log scraping. Every tool runs inside an error-capturing harness in the editor and returns clean JSON, with real Python tracebacks when something fails.
- Self-healing connection. Restart the editor mid-session and the next tool call reconnects automatically.
- An escape hatch.
ue_pythongives Claude the fullunrealmodule for anything the 29 dedicated tools do not cover.
Quickstart
1. Set up Unreal (one time, about 30 seconds)
- Open your project in Unreal Editor.
Edit > Plugins, search for Python Editor Script Plugin, enable it, restart when prompted.Edit > Project Settings, search for Python, check Enable Remote Execution.
That is the entire Unreal-side setup.
2. Add the server to Claude
With uv installed:
Claude Code
claude mcp add unreal -- uvx uemcp
Claude Desktop (claude_desktop_config.json)
{
"mcpServers": {
"unreal": {
"command": "uvx",
"args": ["uemcp"]
}
}
}
pip, or from a clone of this repo
pip install uemcp && uemcp
# or
git clone https://github.com/ATDev-Inc/uemcp && cd uemcp && uv run uemcp
More detail, including pinning to one project when several editors are open: docs/setup.md.
3. Talk to your editor
"Spawn a point light 300 units up, make it warm orange at 8000 intensity, then screenshot the viewport."
"Find every static mesh asset with 'rock' in the name and scatter 20 of them in a rough circle around the origin."
"Create a BP_Collectible blueprint with a static mesh component and a sphere collision, set its mesh to the gold coin asset."
Tools
| Group | Tools |
|---|---|
| Editor | ue_status, ue_python, ue_console_command, ue_project_info |
| Actors | ue_list_actors, ue_spawn_actor, ue_destroy_actor, ue_set_actor_transform, ue_set_actor_property, ue_get_actor |
| Assets | ue_search_assets, ue_asset_info, ue_import_asset, ue_create_folder, ue_duplicate_asset, ue_delete_asset, ue_save_all |
| Materials | ue_create_material, ue_create_material_instance, ue_assign_material |
| Blueprints | ue_create_blueprint, ue_add_component, ue_set_blueprint_default |
| Levels | ue_open_level, ue_new_level |
| Viewport | ue_set_camera, ue_get_camera, ue_focus_actor, ue_screenshot |
| Play | ue_play, ue_stop_play |
Conventions: project content paths look like /Game/Props/SM_Chair, engine classes like /Script/Engine.PointLight. Distances are centimeters, rotations are [roll, pitch, yaw] in degrees, colors are [r, g, b] in 0..1.
Full parameter and return documentation for every tool: docs/tools.md.
How it works
Claude (MCP client)
| stdio (MCP)
v
uemcp server (this package, plain Python)
| UDP multicast 239.0.0.1:6766 -> discovery ping/pong
| TCP command channel -> JSON commands and results
v
Unreal Editor (built-in Python remote execution)
Each tool builds a small Python snippet, wraps it in a harness that catches exceptions, runs it in the editor, and parses a sentinel-prefixed JSON line back out of the log output. The snippet builders are pure functions, so CI compiles every one of them without needing Unreal installed.
Configuration
Everything works with defaults when the editor and server are on the same machine. Override with environment variables when needed:
| Variable | Default | Purpose |
|---|---|---|
UEMCP_PROJECT |
(first found) | Prefer a specific project when several editors are open |
UEMCP_MULTICAST_GROUP |
239.0.0.1 |
Discovery multicast group |
UEMCP_MULTICAST_PORT |
6766 |
Discovery port |
UEMCP_COMMAND_HOST |
127.0.0.1 |
Host the editor connects back to |
UEMCP_COMMAND_TIMEOUT |
120 |
Per-command timeout in seconds |
UEMCP_DISCOVERY_TIMEOUT |
2 |
Discovery wait in seconds |
uemcp --project MyGame is shorthand for UEMCP_PROJECT=MyGame.
Security notes
UEMCP executes Python inside your editor process, by design. Treat it like giving Claude the editor's Python console:
- The remote execution protocol has no authentication. Keep the defaults (localhost command channel, multicast TTL 0) unless you fully control the network.
- Tools can modify and delete project content. Use source control on your project. You should be doing that anyway.
- Review what an agent did with
ue_save_allwithheld if you want a manual checkpoint before anything hits disk.
Documentation
| Doc | What it covers |
|---|---|
| docs/setup.md | Detailed Unreal and client setup, multiple editors, remote machines |
| docs/tools.md | Full reference for all 31 tools: parameters, returns, examples |
| docs/architecture.md | The wire protocol, the snippet harness, and how to add a tool |
| docs/troubleshooting.md | Connection problems, firewalls, common tool errors |
| docs/cookbook.md | Prompt recipes: lighting rigs, greyboxing, asset audits |
Development
git clone https://github.com/ATDev-Inc/uemcp
cd uemcp
uv sync
uv run pytest
uv run ruff check .
The test suite runs entirely without Unreal: protocol tests talk to a fake editor over real sockets, and every in-editor snippet is compile-checked.
Roadmap
- Sequencer tools (create level sequences, bind actors, render movies)
- Niagara system spawning and parameter control
- Landscape sculpting primitives
- True PIE (play-in-editor) control with input injection
- Asset thumbnails as MCP resources
Community
- Contributing: CONTRIBUTING.md has a contribution ladder from docs fixes up to new tools. If you keep reaching for the same
ue_pythonsnippet, that is a tool waiting to be born, and a working snippet pasted into an issue is 80% of the work. - Bugs: use the issue templates. The in-editor traceback from the tool error is the most useful thing you can include.
- Security: see SECURITY.md. Report vulnerabilities privately, not in public issues.
- Releases: CHANGELOG.md and GitHub releases.
- Conduct: CODE_OF_CONDUCT.md.
License
MIT. Copyright (c) 2026 ATDev.
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.