Skip to content

adriendengreville/onshape-mcp

ย 
ย 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

45 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Onshape MCP Server

Enhanced Model Context Protocol (MCP) server for programmatic CAD modeling with Onshape.

Features

This MCP server provides comprehensive programmatic access to Onshape's REST API, enabling:

โœจ Core Capabilities (35 tools)

  • ๐Ÿ” Document Discovery - Search and list projects, find Part Studios, navigate workspaces
  • ๐Ÿ“ Parametric Sketches - Rectangles, circles, lines, and arcs on standard planes
  • โš™๏ธ Feature Management - Extrude, revolve, fillet, chamfer, boolean, and pattern features
  • ๐Ÿ—๏ธ Assembly Management - Create assemblies, add instances, position parts, create mates
  • ๐Ÿ“Š Variable Tables - Read and write Onshape variable tables for parametric designs
  • ๐Ÿงฎ FeatureScript - Evaluate FeatureScript expressions, get bounding boxes
  • ๐Ÿ“ฆ Export - Export Part Studios and Assemblies to STL, STEP, PARASOLID, GLTF, OBJ
  • ๐Ÿ—‚๏ธ Part Studio Management - Create and manage Part Studios programmatically

Installation

Prerequisites

  • Python 3.10 or higher
  • Onshape account with API access
  • Onshape API keys (access key and secret key)

Setup

  1. Clone the repository:
git clone https://github.com/hedless/onshape-mcp.git
cd onshape-mcp
  1. Create a virtual environment:
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate
  1. Install dependencies:
pip install -e .
  1. Set up environment variables:
export ONSHAPE_ACCESS_KEY="your_access_key"
export ONSHAPE_SECRET_KEY="your_secret_key"

Or create a .env file:

ONSHAPE_ACCESS_KEY=your_access_key
ONSHAPE_SECRET_KEY=your_secret_key

Getting Onshape API Keys

  1. Go to Onshape Developer Portal
  2. Sign in with your Onshape account
  3. Create a new API key
  4. Copy the Access Key and Secret Key

Usage

Running the Server

onshape-mcp

Or directly with Python:

python -m onshape_mcp.server

Configuring with Claude Code

Add to your ~/.claude/mcp.json:

{
  "mcpServers": {
    "onshape": {
      "command": "/absolute/path/to/onshape-mcp/venv/bin/python",
      "args": ["-m", "onshape_mcp.server"],
      "env": {
        "ONSHAPE_ACCESS_KEY": "your_access_key_here",
        "ONSHAPE_SECRET_KEY": "your_secret_key_here"
      }
    }
  }
}

Important Notes:

  • Use the absolute path to your virtual environment's Python executable
  • Find your path: cd onshape-mcp && pwd to get the directory path
  • On Windows: Use C:/path/to/onshape-mcp/venv/Scripts/python.exe
  • Replace the API keys with your actual keys from Onshape Developer Portal
  • Restart Claude Code after editing mcp.json

Verify it works: Ask Claude Code: "Can you list my Onshape documents?"

For complete setup instructions, see docs/QUICK_START.md.

Available Tools

๐Ÿ” Document & Navigation Tools

Tool Description
list_documents List documents with filtering (filterType, sortBy, sortOrder, limit)
search_documents Search documents by name or description
get_document Get detailed document information
get_document_summary Get comprehensive summary with workspaces and elements
find_part_studios Find Part Studios with optional name filtering
get_elements Get all elements (Part Studios, Assemblies, BOMs) in a workspace
get_parts Get all parts from a Part Studio
get_assembly Get assembly structure with instances and occurrences
create_document Create a new Onshape document
create_part_studio Create a new Part Studio in a document

๐Ÿ—๏ธ Assembly Tools

Tool Description
create_assembly Create a new Assembly in a document
add_assembly_instance Add a part or sub-assembly instance to an assembly
transform_instance Position/rotate an instance using translation (inches) and rotation (degrees)
create_fastened_mate Create a rigid mate between two instances
create_revolute_mate Create a rotational mate between two instances

๐Ÿ“ Sketch Tools

Tool Description
create_sketch_rectangle Rectangle with optional variable references for width/height
create_sketch_circle Circle with center point and radius
create_sketch_line Line from start point to end point
create_sketch_arc Arc with center, radius, start angle, and end angle

All sketch tools support plane (Front/Top/Right) and name parameters. Dimensions are in inches.

โš™๏ธ Feature Tools

Tool Description
create_extrude Extrude a sketch with depth, optional variable reference, and operation type (NEW/ADD/REMOVE/INTERSECT)
create_revolve Revolve a sketch around an axis (X/Y/Z) with angle and operation type
create_fillet Round edges by edge IDs with radius (supports variable references)
create_chamfer Bevel edges by edge IDs with distance (supports variable references)
create_linear_pattern Repeat features along an axis (X/Y/Z) with distance and count
create_circular_pattern Repeat features around an axis with count and angle spread
create_boolean Union, subtract, or intersect bodies by deterministic IDs

๐Ÿ“Š Variable Tools

Tool Description
get_variables Get all variables from a Part Studio variable table
set_variable Set or update a variable (e.g., "0.75 in")
get_features Get all features from a Part Studio

๐Ÿงฎ FeatureScript Tools

Tool Description
eval_featurescript Evaluate a FeatureScript lambda expression (read-only)
get_bounding_box Get the tight bounding box of all parts in a Part Studio

๐Ÿ“ฆ Export Tools

Tool Description
export_part_studio Export to STL, STEP, PARASOLID, GLTF, or OBJ (optional partId filter)
export_assembly Export to STL, STEP, or GLTF

Architecture

onshape_mcp/
โ”œโ”€โ”€ api/
โ”‚   โ”œโ”€โ”€ client.py         # HTTP client with authentication
โ”‚   โ”œโ”€โ”€ documents.py      # Document discovery & navigation
โ”‚   โ”œโ”€โ”€ partstudio.py     # Part Studio management
โ”‚   โ”œโ”€โ”€ variables.py      # Variable table management
โ”‚   โ”œโ”€โ”€ assemblies.py     # Assembly lifecycle & mates
โ”‚   โ”œโ”€โ”€ export.py         # Part Studio & Assembly export
โ”‚   โ””โ”€โ”€ featurescript.py  # FeatureScript evaluation
โ”œโ”€โ”€ builders/
โ”‚   โ”œโ”€โ”€ sketch.py         # Sketch builder (rectangle, circle, line, arc, polygon)
โ”‚   โ”œโ”€โ”€ extrude.py        # Extrude feature builder
โ”‚   โ”œโ”€โ”€ revolve.py        # Revolve feature builder
โ”‚   โ”œโ”€โ”€ fillet.py         # Fillet feature builder
โ”‚   โ”œโ”€โ”€ chamfer.py        # Chamfer feature builder
โ”‚   โ”œโ”€โ”€ boolean.py        # Boolean operations (union, subtract, intersect)
โ”‚   โ”œโ”€โ”€ pattern.py        # Linear & circular pattern builders
โ”‚   โ”œโ”€โ”€ mate.py           # Mate connector & mate builders
โ”‚   โ””โ”€โ”€ thicken.py        # Thicken feature builder
โ”œโ”€โ”€ tools/
โ”‚   โ””โ”€โ”€ __init__.py       # MCP tool definitions
โ””โ”€โ”€ server.py             # Main MCP server (35 tools)

Examples

Example 1: Finding and Working on a Project

# Search for your project
documents = await search_documents(query="robot arm", limit=5)

# Get the first matching document
doc_id = documents[0].id

# Get comprehensive summary
summary = await get_document_summary(doc_id)

# Find Part Studios in main workspace
workspace_id = summary['workspaces'][0].id
part_studios = await find_part_studios(doc_id, workspace_id, namePattern="base")

# Now work with the Part Studio
elem_id = part_studios[0].id

Example 2: Creating a Parametric Cabinet

# Set variables
await set_variable(doc_id, ws_id, elem_id, "width", "39.5 in")
await set_variable(doc_id, ws_id, elem_id, "depth", "16 in")
await set_variable(doc_id, ws_id, elem_id, "height", "67.125 in")
await set_variable(doc_id, ws_id, elem_id, "wall_thickness", "0.75 in")

# Create side panel sketch
await create_sketch_rectangle(
    doc_id, ws_id, elem_id,
    name="Side Panel",
    plane="Front",
    corner1=[0, 0],
    corner2=[16, 67.125],
    variableWidth="depth",
    variableHeight="height"
)

# Extrude to create side
await create_extrude(
    doc_id, ws_id, elem_id,
    name="Side Extrude",
    sketchFeatureId="<sketch_id>",
    depth=0.75,
    variableDepth="wall_thickness"
)

Development

Running Tests

The project has comprehensive test coverage with 353 unit tests.

# Run all tests
pytest

# Run with coverage
pytest --cov

# Run specific module tests
pytest tests/api/test_documents.py -v

# Use make commands
make test
make test-cov
make coverage-html

For detailed testing documentation, see docs/TESTING.md.

Code Formatting

black .
ruff check .

Documentation

Getting Started

Development & Testing

API & Implementation

Project Analysis & Research

Knowledge Base

Roadmap

Current Status โœ…

  • โœ… Document discovery and navigation (10 tools)
  • โœ… Sketch creation with rectangles, circles, lines, and arcs
  • โœ… Feature tools: extrude, revolve, fillet, chamfer, boolean, patterns
  • โœ… Assembly management with mates and transforms
  • โœ… Variable table management
  • โœ… FeatureScript evaluation and bounding box queries
  • โœ… Export to STL, STEP, PARASOLID, GLTF, OBJ
  • โœ… 353 comprehensive unit tests (86%+ coverage)

In Research ๐Ÿ”ฌ

  • ๐Ÿ”ฌ Geometry-referenced sketch planes - Create sketches on faces from existing features (see docs/SKETCH_PLANE_REFERENCE_GUIDE.md)
  • ๐Ÿ”ฌ Query API investigation - How to programmatically reference geometry
  • ๐Ÿ”ฌ Entity ID mapping - Understanding Onshape's internal ID system

Near-Term Priorities ๐Ÿ“‹

  • Implement create_sketch_on_geometry() for carpentry-correct cabinet assembly
  • Sketch constraints (coincident, parallel, tangent, etc.)
  • Slider and cylindrical mate types
  • Pocket cuts and profiles for joinery (dados, rabbets)

Long-Term Goals ๐ŸŽฏ

  • Drawing creation
  • Bill of Materials (BOM) generation
  • Advanced constraints and relations
  • Configuration parameter support

Woodworking-Specific Features ๐Ÿชš

  • Joinery library (dado, rabbet, mortise & tenon, dovetail)
  • Standard hardware patterns (shelf pins, drawer slides)
  • Cut list generation
  • Material optimization (sheet layout)
  • Assembly instructions generation

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

MIT License

Acknowledgments

Support

For issues and questions:

About

mcp server for interacting with onshape

Resources

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages

  • Python 99.6%
  • Makefile 0.4%