gridfinity-mcp
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., "@gridfinity-mcpmake a 6x1 tray split into 3 compartments, 4 units tall"
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.
Gridfinity MCP
A local MCP server that turns natural-language requests into printable Gridfinity STL/STEP files. No more dragging sliders on a website — ask Claude for "a 6×1 tray split into 3, 4 units tall" and get an STL.
It wraps the cqgridfinity geometry engine (CadQuery / OpenCascade).
Tools
Tool | What it makes | Key inputs |
| A bin |
|
| A baseplate grid |
|
| Edge fillers to fit baseplates into a real drawer |
|
Units: 1 grid unit = 42 mm (X/Y), 1 height unit = 7 mm (Z). All geometry
is standard 42 mm Gridfinity, so everything is cross-compatible with off-the-shelf
Gridfinity parts. Files are written to GRIDFINITY_OUTPUT_DIR (default ~/Gridfinity_STL).
Related MCP server: 3D MCP Server
Install
cd gridfinity-mcp
python3 -m venv .venv && source .venv/bin/activate # recommended
pip install -r requirements.txt
python3 smoke_test.py # confirms the CAD kernel renders on your machinecqgridfinity pulls a matched CadQuery + OpenCascade (cadquery-ocp) automatically.
CadQuery also needs nlopt, which has prebuilt wheels for normal desktop platforms.
Add it to Claude
Add to your MCP config (Claude Desktop: claude_desktop_config.json; Claude
Code / Cowork: .mcp.json). Use absolute paths.
{
"mcpServers": {
"gridfinity": {
"command": "python3",
"args": ["/ABSOLUTE/PATH/TO/gridfinity-mcp/gridfinity_mcp.py"],
"env": { "GRIDFINITY_OUTPUT_DIR": "/ABSOLUTE/PATH/TO/Gridfinity_STL" }
}
}
}If you used a venv, point command at that venv's python, e.g.
/ABSOLUTE/PATH/TO/gridfinity-mcp/.venv/bin/python.
Fitting a 42 mm grid into a non-grid drawer
Real drawers are rarely a multiple of 42 mm. The standard Gridfinity approach (and
what this server does) is: lay the largest whole-cell baseplate that fits, then fill
the leftover lip with spacers. Call gridfinity_generate_drawer_spacer with the
interior drawer size — its summary tells you the baseplate cell count to generate.
Worked example — the kitchen drawer (335 × 500 mm interior)
This keeps the freestanding utensil organizer and fills the rest:
Catch-all area (front-left, ~257.5 × 100 mm): baseplate
6 × 2(252 × 84 mm) + a6 × 2box, or two3 × 2boxes.Back strip (~257.5 × 45 mm): baseplate
6 × 1+ a6 × 1box.Spatula strip (right wall, ~77.5 × 500 mm): baseplate
1 × 11(split for the bed) + boxes; the 77.5 mm width leaves a ~35 mm lip — fill it with a drawer spacer.Lip everywhere: run
gridfinity_generate_drawer_spacer(drawer_width_mm=335, drawer_depth_mm=500)to take up the slack so nothing slides.
Note on the trade-off vs. gridfinitygenerator.com: that website can set a custom grid unit and custom outer size to fill odd widths exactly, but those bins no longer interchange with standard 42 mm parts. This server keeps the true 42 mm standard and absorbs odd drawer dimensions with spacers instead. Pick based on whether cross-compatibility matters to you (it does for the toolbox project).
Notes / limits
v1 covers box, baseplate, and drawer spacer.
GridfinityRuggedBox(lidded cases) and a custom grid-unit option are easy follow-ups.Generation is CPU-bound; large/complex models take a few seconds.
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/zanewebb/gridfinity-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server