uml-diagram
$
npx mdskill add automateyournetwork/netclaw/uml-diagramGenerates UML and diagrams using Kroki for visualization and documentation
- Solves the need for visualizing software architecture and system designs
- Relies on Kroki, PlantUML, and Mermaid.ink for rendering diagrams
- Chooses appropriate diagram type based on user input and requirements
- Returns rendered diagrams in SVG, PNG, or other formats for immediate use
SKILL.md
.github/skills/uml-diagramView on GitHub ↗
---
name: uml-diagram
description: "UML and diagram generation via Kroki — class, sequence, activity, state, component, deployment, network, ER, C4, Mermaid, D2, Graphviz, BPMN, 27+ types. Use when generating a network diagram, creating a sequence diagram, drawing a rack layout, visualizing a protocol state machine, or producing architecture documentation."
license: Apache-2.0
user-invocable: true
metadata:
{ "openclaw": { "requires": { "bins": ["python3"], "env": [] } } }
---
# UML & Diagram Generation via Kroki
## MCP Server
| Property | Value |
|----------|-------|
| **Source** | [antoinebou12/uml-mcp](https://github.com/antoinebou12/uml-mcp) |
| **Transport** | stdio (default) or HTTP |
| **Tools** | 2 (`generate_uml`, `generate_diagram_url`) |
| **Resources** | 8 (diagram types, templates, examples, formats, server info) |
| **Prompts** | 11 (class, sequence, activity, usecase, Mermaid, BPMN, etc.) |
| **Rendering** | Kroki (primary) with PlantUML and Mermaid.ink fallback |
## Tools
### `generate_uml`
Generate a diagram and optionally save to disk.
| Parameter | Type | Default | Description |
|-----------|------|---------|-------------|
| `diagram_type` | string | required | Diagram type (class, sequence, mermaid, d2, graphviz, etc.) |
| `code` | string | required | Diagram source code |
| `output_dir` | string | null | Directory to save file (null = no file write) |
| `output_format` | string | "svg" | Output format: svg, png, pdf, jpeg, txt, base64 |
| `theme` | string | null | PlantUML theme directive |
| `scale` | float | 1.0 | SVG scaling factor (min 0.1) |
**Returns:** `{ code, url, playground, local_path, content_base64, error }`
### `generate_diagram_url`
Get the Kroki rendering URL and optional base64 content without saving to disk.
| Parameter | Type | Default | Description |
|-----------|------|---------|-------------|
| `diagram_type` | string | required | Diagram type |
| `code` | string | required | Diagram source code |
| `output_format` | string | "svg" | Output format |
| `theme` | string | null | PlantUML theme |
| `scale` | float | 1.0 | SVG scaling factor |
**Returns:** `{ code, url, playground, content_base64, error }`
---
## Supported Diagram Types (27+)
### PlantUML-based
| Type | Description | Use Case |
|------|-------------|----------|
| `class` | Class diagrams | Object relationships, inheritance, interfaces |
| `sequence` | Sequence diagrams | Message flows between components |
| `activity` | Activity diagrams | Workflow and process flows |
| `usecase` | Use case diagrams | Actor-system interactions |
| `state` | State machine diagrams | FSM, protocol states |
| `component` | Component diagrams | System architecture |
| `deployment` | Deployment diagrams | Infrastructure layout |
| `object` | Object diagrams | Instance-level relationships |
| `c4plantuml` | C4 architecture | System context, container, component views |
| `plantuml` | Generic PlantUML | Any PlantUML syntax |
### Network & Infrastructure
| Type | Description | Use Case |
|------|-------------|----------|
| `nwdiag` | Network diagrams | Network topology, IP addressing, VLANs |
| `rackdiag` | Rack diagrams | Data center rack layouts |
| `packetdiag` | Packet diagrams | Protocol header formats (Ethernet, IP, TCP) |
| `blockdiag` | Block diagrams | System block diagrams |
| `actdiag` | Activity diagrams | Activity flow (blockdiag family) |
| `seqdiag` | Sequence diagrams | Sequence flow (blockdiag family) |
### Other Backends
| Type | Description | Use Case |
|------|-------------|----------|
| `mermaid` | Mermaid diagrams | Flowcharts, Gantt, sequence, pie, journey |
| `d2` | D2 declarative | Modern declarative diagrams |
| `graphviz` | Graphviz DOT | Graph layouts, dependency trees |
| `erd` | Entity-Relationship | Database schema diagrams |
| `dbml` | Database Markup | Database schema (DBML syntax) |
| `bpmn` | BPMN 2.0 | Business process modeling |
| `structurizr` | Structurizr DSL | C4 model architecture |
| `ditaa` | ASCII art to diagram | Convert ASCII art to polished diagrams |
| `wavedrom` | Digital timing | Protocol timing diagrams, signal waveforms |
| `wireviz` | Wire/cable harness | Cable and connector documentation |
| `bytefield` | Byte field | Binary format documentation |
---
## Network Engineering Examples
### Network Topology (nwdiag)
```
generate_uml(
diagram_type="nwdiag",
code="""
nwdiag {
network dmz {
address = "210.x.x.x/24"
web01 [address = "210.x.x.1"];
web02 [address = "210.x.x.2"];
}
network internal {
address = "172.x.x.x/24"
web01 [address = "172.x.x.1"];
web02 [address = "172.x.x.2"];
db01;
}
}
""",
output_format="svg"
)
```
### Rack Diagram (rackdiag)
```
generate_uml(
diagram_type="rackdiag",
code="""
rackdiag {
16U;
1: UPS;
2: UPS;
3: Patch Panel;
4: Catalyst 9300;
5: Catalyst 9300;
6: Nexus 9000;
7: Nexus 9000;
8: ASR 1001-X;
9: ASR 1001-X;
10: BIG-IP i5800;
11: BIG-IP i5800;
12: UCS C220;
13: UCS C220;
14: UCS C220;
15: UCS C220;
16: Cable Management;
}
""",
output_format="png"
)
```
### Packet Header (packetdiag)
```
generate_uml(
diagram_type="packetdiag",
code="""
packetdiag {
colwidth = 32
node_height = 72
0-3: Version
4-7: IHL
8-15: DSCP / ECN
16-31: Total Length
32-47: Identification
48-50: Flags
51-63: Fragment Offset
64-71: TTL
72-79: Protocol
80-95: Header Checksum
96-127: Source Address
128-159: Destination Address
}
""",
output_format="svg"
)
```
### BGP State Machine (state)
```
generate_uml(
diagram_type="state",
code="""
@startuml
[*] --> Idle
Idle --> Connect : Start
Connect --> OpenSent : TCP established
Connect --> Active : TCP failed
Active --> OpenSent : TCP established
Active --> Connect : ConnectRetry timer
OpenSent --> OpenConfirm : OPEN received (valid)
OpenSent --> Idle : OPEN received (error)
OpenConfirm --> Established : KEEPALIVE received
OpenConfirm --> Idle : Hold timer expired
Established --> Idle : NOTIFICATION / Hold expired
Established : Process UPDATE messages
@enduml
""",
output_format="svg"
)
```
### OSPF Area Design (class)
```
generate_uml(
diagram_type="class",
code="""
@startuml
package "Area 0 - Backbone" {
class "Core-1" as C1 { router-id: 1.1.1.1 }
class "Core-2" as C2 { router-id: 2.2.2.2 }
C1 -- C2 : 10G P2P
}
package "Area 1 - Campus" {
class "Dist-1" as D1 { router-id: 3.3.3.3 }
class "Dist-2" as D2 { router-id: 4.4.4.4 }
}
package "Area 2 - DC" {
class "Spine-1" as S1 { router-id: 5.5.5.5 }
class "Spine-2" as S2 { router-id: 6.6.6.6 }
}
C1 -- D1 : ABR
C2 -- D2 : ABR
C1 -- S1 : ABR
C2 -- S2 : ABR
@enduml
""",
output_format="svg"
)
```
### Sequence: Change Request Flow
```
generate_uml(
diagram_type="sequence",
code="""
@startuml
actor Engineer
participant NetClaw
participant ServiceNow
participant Device
participant GAIT
Engineer -> NetClaw : "Add Loopback99"
NetClaw -> ServiceNow : Create Change Request
ServiceNow --> NetClaw : CR-12345 (New)
NetClaw -> ServiceNow : Wait for approval
ServiceNow --> NetClaw : CR-12345 (Implement)
NetClaw -> Device : Capture baseline
Device --> NetClaw : Running config
NetClaw -> Device : Apply config
Device --> NetClaw : Config applied
NetClaw -> Device : Verify change
Device --> NetClaw : Loopback99 up/up
NetClaw -> ServiceNow : Close CR-12345
NetClaw -> GAIT : Record full audit trail
NetClaw --> Engineer : Done. Verified.
@enduml
""",
output_format="svg"
)
```
### C4 Architecture (structurizr)
```
generate_uml(
diagram_type="structurizr",
code="""
workspace {
model {
engineer = person "Network Engineer"
netclaw = softwareSystem "NetClaw" {
openclaw = container "OpenClaw Agent"
pyats = container "pyATS MCP"
gait = container "GAIT MCP"
}
network = softwareSystem "Network Devices"
servicenow = softwareSystem "ServiceNow"
engineer -> openclaw "Chat"
openclaw -> pyats "MCP (stdio)"
openclaw -> gait "MCP (stdio)"
pyats -> network "SSH/NETCONF"
openclaw -> servicenow "REST API"
}
views {
container netclaw {
include *
autoLayout
}
}
}
""",
output_format="svg"
)
```
---
## Workflows
### 1. Network Topology Documentation
```
pyats-topology → CDP/LLDP discovery data
→ generate_uml(type="nwdiag") → network topology diagram
→ msgraph-files → upload to SharePoint
→ GAIT
```
### 2. Protocol State Machine Reference
```
generate_uml(type="state") → BGP/OSPF/STP state machine
→ Share in Slack/Teams for team reference
→ GAIT
```
### 3. Change Request Visualization
```
servicenow-change-workflow → CR details
→ generate_uml(type="sequence") → change flow diagram
→ Attach to ServiceNow CR or GAIT log
→ GAIT
```
### 4. Data Center Rack Documentation
```
generate_uml(type="rackdiag") → rack layout
→ generate_uml(type="nwdiag") → network connections
→ Cross-reference with NetBox rack/device data
→ msgraph-files → upload to SharePoint
→ GAIT
```
### 5. Packet Format Reference
```
generate_uml(type="packetdiag") → protocol header diagram
→ rfc-lookup → verify against RFC
→ Share as reference material
→ GAIT
```
### 6. Architecture Documentation
```
generate_uml(type="structurizr" or "c4plantuml") → C4 architecture views
→ generate_uml(type="deployment") → deployment diagram
→ generate_uml(type="component") → component breakdown
→ msgraph-files → upload to SharePoint
→ GAIT
```
---
## Integration with Other Skills
| Skill | Integration |
|-------|-------------|
| **pyats-topology** | Feed CDP/LLDP discovery data into nwdiag for topology diagrams |
| **drawio-diagram** | UML MCP for standards-based UML; Draw.io for freeform network diagrams |
| **markmap-viz** | Markmap for hierarchical mind maps; UML for structured diagrams |
| **netbox-reconcile** | Generate nwdiag diagrams color-coded by reconciliation status |
| **rfc-lookup** | Pair packetdiag with RFC references for protocol documentation |
| **servicenow-change-workflow** | Sequence diagrams documenting change request flows |
| **msgraph-files** | Upload generated diagrams to SharePoint |
| **msgraph-teams** | Share diagram URLs in Teams channels |
| **gait-session-tracking** | Record all diagram generation in GAIT |
---
## Comparison: UML MCP vs Draw.io vs Markmap
| Feature | UML MCP | Draw.io | Markmap |
|---------|---------|---------|---------|
| **Best for** | Structured UML, protocol diagrams, architecture | Freeform network topology | Hierarchical mind maps |
| **Diagram types** | 27+ (class, sequence, nwdiag, rack, packet, etc.) | Network topology, flowcharts | Mind maps from markdown |
| **Rendering** | Kroki (server-side) | Browser or CLI | Browser |
| **Output** | SVG, PNG, PDF, JPEG | .drawio, PNG, SVG, PDF | HTML |
| **Code-based** | Yes (PlantUML, Mermaid, D2, DOT, etc.) | XML/Mermaid/CSV | Markdown |
| **Network-specific** | nwdiag, rackdiag, packetdiag | Full topology editor | OSPF/BGP hierarchies |
**When to use UML MCP:**
- Protocol state machines (BGP FSM, OSPF states, STP states)
- Network topology diagrams from code (nwdiag)
- Rack layouts (rackdiag)
- Packet header documentation (packetdiag)
- Sequence diagrams (change workflows, protocol exchanges)
- Architecture documentation (C4, component, deployment)
- Database schema diagrams (ERD, DBML)
- Any diagram type supported by Kroki
**When to use Draw.io:**
- Interactive topology editing
- Native .drawio files for team collaboration
- Color-coded reconciliation status overlays
**When to use Markmap:**
- Hierarchical data (OSPF areas, BGP peers, config structure)
- Quick visual summaries from markdown
---
## Guardrails
- **All operations are read-only** — generates diagrams, never modifies network state
- **Public Kroki by default** — diagram source code is sent to kroki.io for rendering; use a local Kroki instance (`KROKI_SERVER`) for sensitive topology data
- **No secrets in diagrams** — never include IP credentials, passwords, or SNMP communities in diagram source code
- **Record in GAIT** — every diagram generation must be logged
More from automateyournetwork/netclaw
- aap-automationRed Hat Ansible Automation Platform — inventory management, job template execution, project SCM sync, ad-hoc commands, host management, Galaxy content discovery. Use when automating infrastructure with Ansible, running playbooks, managing inventories, or searching for Ansible collections and roles.
- aap-edaEvent-Driven Ansible (EDA) — activation lifecycle, rulebook management, decision environments, event stream monitoring. Use when managing event-driven automation triggers, enabling/disabling activations, or reviewing EDA rulebooks.
- aap-lintansible-lint playbook and role validation — syntax checking, best practice enforcement, project-wide analysis, rule filtering. Use when validating Ansible playbooks, checking code quality, or enforcing automation best practices before deployment.
- aci-change-deploySafe ACI policy change deployment - ServiceNow CR lifecycle, pre/post-change fault baselines, APIC policy application, automatic rollback on fault delta, and GAIT audit trail. Use when deploying ACI policy changes, creating tenants or EPGs, pushing config to APIC, or running a change window with rollback protection.
- aci-fabric-auditComprehensive Cisco ACI fabric health audit - node status, tenant/VRF/BD/EPG policy review, contract analysis, fault triage, and endpoint learning verification. Use when auditing ACI fabric health, checking for faults, reviewing tenant policies, or running pre/post-change baselines on APIC.
- arista-cvpArista CloudVision Portal (CVP) automation via REST API — device inventory, events, connectivity monitoring, tag management (4 tools). Use when managing Arista devices, checking CloudVision events, monitoring network connectivity probes, or tagging devices in CVP.
- aruba-cx-configView and manage Aruba CX switch configurations, perform ISSU upgrades, and firmware operations
- aruba-cx-interfacesMonitor Aruba CX switch interface status, LLDP neighbors, and optical transceiver health
- aruba-cx-switchingView and manage Aruba CX switch VLANs and MAC address tables for Layer 2 operations
- aruba-cx-systemDiscover Aruba CX switch system information, firmware versions, and VSF topology