Revit MCP Server
Provides 45 tools for building design, editing, analysis, MEP, interop, and documentation via Autodesk Revit API, accessible through pyRevit.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Revit MCP Servercreate a new level at elevation 10 feet"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Revit MCP Server
MCP server for Autodesk Revit 2024/2025/2026 via pyRevit — 45 tools for building design, editing, analysis, MEP, interop, and documentation.
Works with any MCP client: Claude Desktop, Claude Code, Cursor, Windsurf, Copilot, or any other MCP-compatible application.
How It Works
AI Client ──stdio/SSE/HTTP──> MCP Server (Python/FastMCP) ──HTTP :48884──> pyRevit Routes ──> Revit APIThe MCP server runs on your machine and communicates with Revit through pyRevit's Routes API. Any MCP-compatible AI client can connect to it.
Prerequisites
Requirement | Details |
Windows 10/11 | Revit is Windows-only |
Autodesk Revit | 2024, 2025, or 2026 |
pyRevit | Installed and loaded in Revit |
uv | Python package manager (install) |
A project open in Revit | Tools require an active document |
Install pyRevit (if not already installed)
pyRevit is a free add-in that lets scripts run inside Revit. This MCP server needs it to communicate with Revit.
Download the latest .exe installer (e.g.
pyRevit_CLI_x.x.x.x_admin_signed.exe)Run the installer — accept all defaults, click Next through each screen
Open (or restart) Revit — you should see a pyRevit tab in the ribbon at the top
In the pyRevit tab, click Settings (gear icon)
In the Settings window, go to the Routes section on the left
Check the box to Enable Routes Server
Click Save Settings and let pyRevit reload
To verify: open a browser and go to http://localhost:48884/ — you should see a response (not a "connection refused" error).
Quick Start
Step 1: Clone and install
git clone https://github.com/Demolinator/revit-mcp-server.git
cd revit-mcp-server
uv syncStep 2: Install the pyRevit extension
The revit_mcp/ folder and startup.py need to run inside Revit via pyRevit.
Option A — Install from pyRevit (recommended):
In Revit, go to pyRevit tab > Extensions
Find "MCP Server for Revit Python" > Install
Wait for pyRevit to reload
Option B — Manual install:
Copy the entire repo folder to
%APPDATA%\pyRevit\Extensions\Rename the folder to
mcp-server-for-revit-python.extensionIn Revit, go to pyRevit tab > Settings > Custom Extensions
Add the path to the
.extensionfolderReload pyRevit (or restart Revit)
Step 3: Activate pyRevit Routes
In Revit, go to pyRevit tab > Settings
Navigate to Routes > activate Routes Server
pyRevit will start listening on
http://localhost:48884/
Step 4: Verify connection
Open a browser and go to:
http://localhost:48884/revit_mcp/status/You should see:
{
"status": "active",
"health": "healthy",
"revit_available": true,
"document_title": "your_project_name",
"api_name": "revit_mcp"
}Step 5: Start the MCP server
uv run main.pyThat's it. Your AI client can now connect.
Connecting Your AI Client
Claude Desktop / Claude Code
Add to your MCP config:
{
"mcpServers": {
"revit": {
"command": "uv",
"args": ["run", "main.py"],
"cwd": "/path/to/revit-mcp-server"
}
}
}Cursor / Windsurf / Other MCP Clients
Use HTTP transport:
uv run main.py --streamable-httpThen configure your client to connect to http://localhost:8000/mcp.
Transport Modes
Flag | Transport | Endpoints | Use Case |
(none) | stdio | stdin/stdout | Claude Desktop / Claude Code |
| SSE |
| Legacy clients |
| HTTP |
| HTTP-based clients |
| Both | All above | Maximum compatibility |
Testing with MCP Inspector
mcp dev main.pyThen open http://127.0.0.1:6274 in your browser.
Supported Tools (45)
Create (15)
Tool | Description |
| Create new levels with elevations |
| Create walls, beams, and other line-based elements |
| Create floors, roofs, and surface elements |
| Place a family instance at specified location |
| Create column grid lines |
| Create structural beams and framing |
| Create new drawing sheets |
| Create schedules with custom fields |
| Create rooms at specified levels |
| Create room separation boundary lines |
| Create ducts between two points (MEP) |
| Create pipes between two points (MEP) |
| Create mechanical or piping systems |
| Create view-specific detail lines |
| Create floor plans, sections, elevations, 3D views |
Query (12)
Tool | Description |
| Check if the API is active and responding |
| Get model information |
| Get all levels with elevations |
| Get available family types |
| Get all family categories |
| Export a view as an image |
| List all exportable views |
| Get active view details |
| Get elements in current view |
| Get currently selected elements |
| List parameters for a category |
| Get all parameters and properties of an element |
Modify (8)
Tool | Description |
| Delete elements from the model |
| Modify element parameter values |
| Color elements by parameter values |
| Reset element colors |
| Tag all walls in current view |
| Set a single parameter value on an element |
| Tag specific elements with annotation symbols |
| Move, copy, rotate, or mirror elements |
| Switch the active view in Revit |
Analyze (4)
Tool | Description |
| Filter elements by category and parameters |
| Export room areas, volumes, boundaries |
| Material takeoff data |
| Element counts and model stats |
Document (3)
Tool | Description |
| Create dimension annotations |
| Export views to PDF or image |
Interop (2)
Tool | Description |
| Export model to IFC format (IFC2x3/IFC4) |
| Link or import DWG, DXF, DGN, or RVT files |
Advanced (1)
Tool | Description |
| Execute IronPython code in Revit context |
Architecture
Two runtimes communicate over HTTP:
Component | Runtime | Location | Purpose |
| Python 3.11+ (CPython) | Your machine | MCP protocol, tool definitions |
| IronPython 2.7 (inside Revit) | Revit process | pyRevit route handlers, Revit API |
Multi-Version Revit Support
This server supports Revit 2024, 2025, and 2026 through centralized helper functions that handle the ElementId API differences across versions:
get_element_id_value()— Extracts integer IDs using.Value(2024+) with.IntegerValuefallbackmake_element_id()— Creates ElementIds usingSystem.Int64(2024+) withintfallback
No configuration needed — version detection is automatic via try/except at runtime.
Unit Handling
All tools accept millimeters (mm). The server converts to Revit's internal feet.
From | To mm |
meters | x 1000 |
feet | x 304.8 |
inches | x 25.4 |
Creating Your Own Tools
Adding a new tool requires 2 files + 2 registration lines:
Route handler in
revit_mcp/new_module.py(IronPython 2.7)Tool definition in
tools/new_tools.py(Python 3.11+)Register routes in
startup.pyRegister tools in
tools/__init__.py
See LLM.txt for full context that helps AI assistants understand the codebase.
Contributing
Contributions are welcome! Feel free to submit pull requests or open issues.
Author
Talal Ahmed
License
MIT
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Demolinator/revit-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server