staruml-controller-erd-mcp
An MCP server for AI assistants to programmatically create and manage Entity-Relationship Diagrams in StarUML, including full CRUD operations and PostgreSQL DDL generation.
README
StarUML Controller MCP Server — ERD
An MCP (Model Context Protocol) server specialized for Entity-Relationship Diagrams. Enables AI assistants like Claude to programmatically create and manage ER diagrams in StarUML — from data models, entities, columns, relationships, indexes, and sequences to PostgreSQL DDL generation.
<p align="center"> <img src="images/demo-erd-creation.gif" alt="AI generating a Web Shopping ER diagram in StarUML via MCP" width="800"> <br> <em>AI creating a complete Web Shopping ER diagram through MCP tools</em> </p>
<p align="center"> <img src="images/demo-ddl-generation.jpg" alt="PostgreSQL DDL generated from an ER diagram" width="800"> <br> <em>PostgreSQL DDL exported from the ER diagram — ready for production</em> </p>
Architecture
<p align="center"> <img src="images/architecture.svg" alt="Architecture: Claude ↔ MCP (stdio) ↔ staruml-controller-erd-mcp ↔ HTTP REST API ↔ StarUML" width="800"> </p>
Prerequisites
- Node.js 18+
- StarUML with the staruml-controller extension installed and running
Setup
1. Clone and build the core package
git clone https://github.com/pontasan/staruml-controller-mcp-core.git
cd staruml-controller-mcp-core
npm install && npm run build
cd ..
2. Clone and build this package
git clone https://github.com/pontasan/staruml-controller-erd-mcp.git
cd staruml-controller-erd-mcp
npm install && npm run build
3. Start the StarUML Controller Server
- Launch StarUML and open a project (or create a new one)
- From the menu bar, select Tools > StarUML Controller > Start Server...
<p align="center"> <img src="images/start-server.jpg" alt="Tools menu showing StarUML Controller > Start Server" width="700"> </p>
- Enter a port (default:
12345) and click OK
<p align="center"> <img src="images/port-dialog.jpg" alt="Port number input dialog with default value 12345" width="400"> </p>
- The HTTP server starts — all ERD tools become available via MCP
4. Configure your AI assistant
Claude Code — add to your project's .mcp.json:
{
"mcpServers": {
"staruml-erd": {
"command": "node",
"args": ["/absolute/path/to/staruml-controller-erd-mcp/dist/index.js"]
}
}
}
Or via CLI:
claude mcp add staruml-erd node /absolute/path/to/staruml-controller-erd-mcp/dist/index.js
Claude Desktop — add to your config file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"staruml-erd": {
"command": "node",
"args": ["/absolute/path/to/staruml-controller-erd-mcp/dist/index.js"]
}
}
}
- Restart your AI assistant.
Available Tools
All tools accept optional host (default: localhost) and port (default: 12345) parameters.
ERD Tools
The core of this server — full CRUD for every ERD resource plus DDL generation.
| Resource | Tools |
|---|---|
| Data Models | erd_list_data_models, erd_create_data_model, erd_get_data_model, erd_update_data_model, erd_delete_data_model |
| Diagrams | erd_list_diagrams, erd_create_diagram, erd_get_diagram, erd_update_diagram, erd_delete_diagram |
| Entities | erd_list_entities, erd_create_entity, erd_get_entity, erd_update_entity, erd_delete_entity |
| Columns | erd_list_columns, erd_create_column, erd_get_column, erd_update_column, erd_delete_column |
| Relationships | erd_list_relationships, erd_create_relationship, erd_get_relationship, erd_update_relationship, erd_delete_relationship |
| Indexes | erd_list_indexes, erd_create_index, erd_get_index, erd_update_index, erd_delete_index |
| Sequences | erd_list_sequences, erd_create_sequence, erd_get_sequence, erd_update_sequence, erd_delete_sequence |
| DDL | erd_generate_ddl |
Common Tools
Shared infrastructure tools available across all StarUML Controller MCP servers.
<details> <summary><strong>General</strong> — status, elements, tags, project I/O</summary>
| Tool | Description |
|---|---|
get_status |
Get server status, version, and endpoint list |
get_element |
Get any element by ID |
list_element_tags |
List tags on an element |
create_element_tag |
Create a tag on an element |
get_tag |
Get tag details |
update_tag |
Update a tag |
delete_tag |
Delete a tag |
save_project |
Save project to a .mdj file |
open_project |
Open a .mdj project file |
</details>
<details> <summary><strong>Project</strong> — new, close, import, export</summary>
| Tool | Description |
|---|---|
project_new |
Create a new empty project |
project_close |
Close the current project |
project_import |
Import a .mdj fragment into the project |
project_export |
Export a model fragment to a .mdj file |
project_export_all |
Export all diagrams as images (PNG/SVG/JPEG/PDF) |
project_export_doc |
Export project documentation (HTML/Markdown) |
</details>
<details> <summary><strong>Utility</strong> — undo, redo, search, validate, mermaid, generate</summary>
| Tool | Description |
|---|---|
undo |
Undo the last action |
redo |
Redo the last undone action |
search |
Search elements by keyword with optional type filter |
validate |
Run model validation |
mermaid_import |
Import a Mermaid diagram definition |
generate_diagram |
Generate a diagram from natural language (requires AI extension) |
</details>
<details> <summary><strong>Diagrams</strong> — CRUD, export, layout, zoom</summary>
| Tool | Description |
|---|---|
diagram_list |
List all diagrams (optionally filter by type) |
diagram_create |
Create a new diagram of any type |
diagram_get |
Get diagram details by ID |
diagram_update |
Update diagram name |
diagram_delete |
Delete a diagram |
diagram_list_elements |
List all elements on a diagram |
diagram_list_views |
List all views on a diagram |
diagram_create_element |
Create a node element on a diagram |
diagram_create_relation |
Create a relation between elements |
diagram_export |
Export diagram as image (PNG/SVG/JPEG/PDF) |
diagram_layout |
Auto-layout diagram with configurable direction |
diagram_open |
Open/activate a diagram in the editor |
diagram_zoom |
Set diagram zoom level |
diagram_create_view_of |
Create a view of an existing model on a diagram |
diagram_link_object |
Create a UMLLinkObject on an object diagram |
</details>
<details> <summary><strong>Notes & Shapes</strong> — notes, note links, free lines, shapes</summary>
| Tool | Description |
|---|---|
note_list |
List all notes on a diagram |
note_create |
Create a note with text and position |
note_get |
Get note details |
note_update |
Update note text |
note_delete |
Delete a note |
note_link_list |
List all note links on a diagram |
note_link_create |
Create a link between a note and an element |
note_link_delete |
Delete a note link |
free_line_list |
List all free lines on a diagram |
free_line_create |
Create a free line on a diagram |
free_line_delete |
Delete a free line |
shape_list |
List all shapes on a diagram |
shape_create |
Create a shape (Text, TextBox, Rect, RoundRect, Ellipse, Hyperlink, Image) |
shape_get |
Get shape details |
shape_update |
Update shape text |
shape_delete |
Delete a shape |
</details>
<details> <summary><strong>Views & Elements</strong> — positioning, styling, element management</summary>
| Tool | Description |
|---|---|
view_update |
Move/resize a view (left, top, width, height) |
view_update_style |
Update visual style (fillColor, lineColor, fontColor, fontSize, etc.) |
view_reconnect |
Reconnect an edge to different source/target |
view_align |
Align/distribute multiple views |
element_update |
Update any element's name and documentation |
element_delete |
Delete any element by ID |
element_list_relationships |
List all relationships of an element |
element_list_views |
List all views of an element across diagrams |
element_relocate |
Move element to a different parent |
element_create_child |
Create a child element (attribute, operation, etc.) |
element_reorder |
Reorder element within parent (up/down) |
</details>
Typical Workflow
1. erd_create_data_model → Create a data model container
2. erd_create_diagram → Create an ER diagram
3. erd_create_entity (x N) → Create entities (tables)
4. erd_create_column (x N) → Add columns to each entity
5. erd_create_relationship → Define relationships between entities
6. erd_create_index → Add indexes for performance
7. diagram_export → Export as PNG/SVG
8. erd_generate_ddl → Generate PostgreSQL DDL
Related Projects
This server is part of the StarUML Controller MCP family:
| Server | Diagram Type |
|---|---|
| staruml-controller-erd-mcp | Entity-Relationship Diagram |
| staruml-controller-seq-mcp | Sequence Diagram |
| staruml-controller-class-mcp | Class / Package Diagram |
| staruml-controller-usecase-mcp | Use Case Diagram |
| staruml-controller-activity-mcp | Activity Diagram |
| staruml-controller-bpmn-mcp | BPMN Diagram |
| staruml-controller-sysml-mcp | SysML Diagram |
| and 18 more... |
All servers share common tools and add diagram-specific tools on top. Install only what you need.
License
MIT
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.