UEMCP

UEMCP

Enables Claude to control Unreal Engine 5 editor, spawn actors, build materials, author Blueprints, and more, with zero plugin installation.

Category
Visit Server

README

UEMCP

CI PyPI Python License: MIT

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_python gives Claude the full unreal module for anything the 29 dedicated tools do not cover.

Quickstart

1. Set up Unreal (one time, about 30 seconds)

  1. Open your project in Unreal Editor.
  2. Edit > Plugins, search for Python Editor Script Plugin, enable it, restart when prompted.
  3. 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_all withheld 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_python snippet, 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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured