OpenAEC MCP
Planned integration for editing and managing AutoCAD drawings, enabling AI agents to inspect, plan, validate, and modify engineering documents through the MCP safety workflow.
Planned integration with Autodesk Platform Services (APS) for cloud-based document management and engineering workflows.
Planned integration for interacting with FreeCAD models, allowing AI agents to perform geometry operations and document modifications within a safety-controlled environment.
Planned integration for QGIS, enabling AI agents to manage geospatial data, perform validation, and execute transactions on GIS documents.
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., "@OpenAEC MCPlist all available documents and their current revision status"
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.
OpenAEC MCP
OpenAEC MCP is an independent, safety-first Model Context Protocol platform for AEC applications. It separates MCP protocol handling from host-specific adapters so AI assistants can inspect, plan, validate, and—only after policy and approval checks—modify engineering documents.
Phase 1 is implemented: the server starts over stdio or authenticated Streamable HTTP, exposes tools/resources/prompts, negotiates capabilities, executes a complete plan → approve → transaction workflow against a synthetic in-memory adapter, emits redacted audit events, and passes protocol and safety tests. Desktop and cloud adapters remain explicitly unavailable until their public host APIs are implemented and verified.
Engineering disclaimer: AI-generated or automated engineering output is not a substitute for professional judgment. A qualified professional must review and approve work products, assumptions, units, coordinate systems, and applicable standards.
Architecture
flowchart LR
Client["MCP client"] -->|"stdio or authenticated Streamable HTTP"| Server["MCP server core"]
Server --> Catalog["Capability-gated tool catalog"]
Catalog --> Safety["Safety and approval engine"]
Safety --> Contract["Language-neutral adapter contract"]
Contract --> Fake["In-memory CI adapter"]
Contract -. "future verified adapters" .-> Hosts["AutoCAD · Civil 3D · Revit · QGIS · FreeCAD · APS"]
Server --> Resources["Resources and prompts"]
Safety --> Audit["Redacted audit log"]
Contract --> Validation["Versioned validation rules"]The detailed proposal, interaction model, risk register, milestones, final directory tree, and exact Phase 1 file manifest are in docs/architecture/phase-1.md.
Related MCP server: Fusion MCP
Current support
Application / adapter | Status | Capability advertised |
Synthetic in-memory adapter | Implemented and tested | Document reads, line plan/write, transactions, validation |
AutoCAD | Planned Phase 2 | None |
Civil 3D | Planned Phase 3 | None |
QGIS | Planned Phase 4 | None |
Revit | Planned Phase 4 | None |
FreeCAD | Planned Phase 4 | None |
Autodesk Platform Services | Planned Phase 5 | None |
Unsupported applications are never simulated and their tools are not advertised. See compatibility strategy.
Quick start
Requirements: Node.js 22 or newer.
npm install
npm run build
node apps/mcp-server/dist/cli.js doctor
node apps/mcp-server/dist/cli.jsFor a local MCP client after publication:
{
"mcpServers": {
"open-aec": {
"command": "npx",
"args": ["-y", "@venkatchavan/open-aec-mcp"]
}
}
}During repository development, replace the command and arguments with node and the absolute path to apps/mcp-server/dist/cli.js.
Remote Streamable HTTP
HTTP binds to loopback by default and refuses to start without a bearer token of at least 32 characters.
OPENAEC_TRANSPORT=http \
OPENAEC_HTTP_TOKEN='replace-with-at-least-32-random-characters' \
node apps/mcp-server/dist/cli.jsEndpoints: POST /mcp, GET /health, and GET /ready. The MCP endpoint requires Authorization: Bearer …. Public binding is denied unless explicitly enabled; production remote deployment additionally requires a trusted TLS/authentication gateway.
Safety workflow
The default mode is inspect. It permits reads, calculations, and dry-run plans but blocks approval and execution.
Call
aec.geometry.create_line_planwith explicit units, expected document ID/revision, transaction name, and idempotency key.Review affected objects, warnings, CRS, files, approval requirements, and rollback strategy.
In
assistedmode, callaec.transaction.approve_change_planas an identified operator.Call
aec.transaction.execute_change_planwith the short-lived, plan-scoped approval token.The engine rechecks policy, expiry, adapter, document revision, object limits, idempotency, and the per-document write lock before dispatch.
The test adapter uses snapshot rollback. Real adapters must use valid host-native transactions, document locks, and main-thread dispatch where required.
MCP surface
Phase 1 implements nine task-oriented tools under aec.system.*, aec.document.*, aec.geometry.*, aec.transaction.*, and aec.validation.*. Tool documentation is generated from source metadata with npm run docs:tools.
Resources include:
aec://applicationsaec://documentsaec://documents/{documentId}aec://documents/{documentId}/validation/latestaec://capabilitiesaec://standardsaec://audit/history
All 14 requested engineering workflow prompts are registered. See resources and prompts.
CLI
open-aec-mcp
open-aec-mcp doctor
open-aec-mcp configure
open-aec-mcp list-adapters
open-aec-mcp validate-config ./open-aec.jsondoctor checks Node, parsed configuration, installed adapters, bridge readiness, authentication, port conflicts for HTTP, and transport readiness without printing secrets.
Development and testing
npm run verify
npm run test:coverageThe test suite covers MCP discovery, policy enforcement, approval, stale revisions, idempotency, rollback, unit conversion, redaction, capability filtering, transport security, and validation reports. Use the official MCP Inspector as described in docs/testing.md.
Security
Drawing/model text, block attributes, metadata, external references, and linked-model content are untrusted data—not instructions. The server rejects public binding by default, hashes redacted inputs, never exposes a shell/eval tool, and never advertises unavailable host capabilities. Read SECURITY.md and the threat model before enabling writes.
Roadmap
Phase 1: core, contracts, fake adapter, safety, audit, configuration, protocol surface, tests—implemented.
Phase 2: verified AutoCAD public API adapter and packaging.
Phase 3: verified Civil 3D vertical workflows.
Phase 4: QGIS, Revit, and FreeCAD adapters.
Phase 5: APS adapter and hardened remote deployment.
Phase 6: installers, conformance/performance hardening, signed release artifacts, and registry publishing.
Limitations
Only the synthetic adapter is enabled in Phase 1.
Change plans and approvals are in memory; process restart invalidates them.
HTTP is stateless at the MCP transport layer; application state is shared in the server runtime.
Validation rules are examples and advisory, not jurisdiction-specific design standards.
Binary desktop plugins, installers, signing, APS, and production database persistence are later-phase work.
Trademark and affiliation disclaimer
OpenAEC MCP is independent community software. It is not affiliated with, endorsed by, sponsored by, or an official product of Autodesk, QGIS.org, the FreeCAD project, or any other vendor. Autodesk, AutoCAD, Civil 3D, Revit, QGIS, FreeCAD, and other product names are trademarks of their respective owners and are used only for truthful compatibility descriptions. No third-party logos are included.
Licensed under Apache-2.0. See LICENSE, NOTICE, and THIRD_PARTY_NOTICES.md.
This server cannot be installed
Maintenance
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/Venkatchavan/OpenAEC-MCP'
If you have feedback or need assistance with the MCP directory API, please join our Discord server