Skip to main content
Glama

PlantUML MCP Server

Flexible Model Context Protocol (MCP) server that turns PlantUML snippets into shareable diagrams.
All capabilities are exposed over HTTP, Server-Sent Events (SSE), and STDIO, so you can plug the server into Claude Desktop, Flowise, or any other MCP-compatible runtime.


Key Features

  • ๐Ÿงฐ Tools: generate_plantuml_diagram, generate_capability_landscape, generate_business_scenario, encode_plantuml, decode_plantuml

  • ๐Ÿงพ Prompts: plantuml_error_handling, capability_landscape_input_format, archimate_diagram_input_format, business_scenario_input_format

  • ๐Ÿ“š Static resources: resource://plantuml/server-guide, resource://plantuml/archimate-mapping

  • ๐Ÿ”’ Optional Bearer authentication via MCP_API_KEY

  • โ˜๏ธ Optional ob-file export via signed download URLs (OB_FILE_API_BASE_URL)

  • ๐Ÿ” Optional OIDC client-credentials flow for ob-file (OB_FILE_OIDC_*)

  • ๐Ÿ“ Fallback shared-volume export (GENERATED_FILES_DIR + PUBLIC_FILE_BASE_URL)


Requirements

  • Node.js 18+

  • npm 9+

npm install
npm run build     # emits dist/plantuml-mcp-server.js

Use npx plantuml-mcp-server or node dist/plantuml-mcp-server.js once built.


Transport Modes

Mode

When to use

How to start

HTTP (default)

Direct REST-style integration, reverse proxies, health checks

MCP_TRANSPORT=http node dist/plantuml-mcp-server.js

SSE

Claude Desktop / Flowise over the network with push updates

MCP_TRANSPORT=sse node dist/plantuml-mcp-server.js

STDIO

Local CLI tools (npx, Claude Code CLI, Flowise managed process)

MCP_TRANSPORT=stdio npx plantuml-mcp-server

HTTP transport

MCP_TRANSPORT=http \
MCP_HOST=0.0.0.0 \
MCP_PORT=8765 \
MCP_HTTP_PATH=/mcp \
node dist/plantuml-mcp-server.js
  • POST /mcp to initialize and send JSON-RPC payloads.

  • GET /mcp and DELETE /mcp keep the streamable session alive.

  • GET /healthz is available for readiness probes.

  • Sample client settings: client_config_http.json.

SSE transport

MCP_TRANSPORT=sse \
MCP_HOST=0.0.0.0 \
MCP_PORT=8765 \
MCP_SSE_PATH=/sse \
MCP_SSE_MESSAGES_PATH=/messages \
node dist/plantuml-mcp-server.js
  • Clients connect to /sse (GET) for events and POST JSON messages to /messages.

  • Sample config for Claude Desktop / Flowise: client_config_sse.json.

STDIO transport

MCP_TRANSPORT=stdio npx plantuml-mcp-server
# or run the compiled file directly
MCP_TRANSPORT=stdio node dist/plantuml-mcp-server.js
  • Ideal for local experiments, mcp CLI, or Flowise nodes that spawn the binary.

  • Example setups live in client_config_stdio.json.


Sample Client Configurations

Drop these files into your MCP-aware client or copy the snippets as needed. Update hostnames, ports, and API keys to match your deployment.


Environment Variables

Variable

Default

Purpose

LOG_LEVEL

info

emergency โ†’ debug supported

PLANTUML_SERVER_URL

https://www.plantuml.com/plantuml

Upstream PlantUML renderer

MCP_TRANSPORT

http

http, sse, or stdio

MCP_HOST / MCP_PORT

0.0.0.0 / 3000

Bind address + port (HTTP/SSE)

MCP_HTTP_PATH

/mcp

HTTP JSON-RPC endpoint

MCP_HTTP_ENABLE_JSON_RESPONSES

false

Return JSON body when true (for debugging)

MCP_SSE_PATH

/sse

SSE stream endpoint

MCP_SSE_MESSAGES_PATH

/messages

Message ingestion endpoint

MCP_API_KEY

unset

Enables Bearer auth when provided

OB_FILE_API_BASE_URL

unset

ob-file management API base URL (for example http://ob-file:8000)

OB_FILE_API_TOKEN

unset

Bearer token used to call the ob-file management API

OB_FILE_OIDC_DISCOVERY_URL

unset

Authelia OIDC discovery URL used to obtain a service access token

OB_FILE_OIDC_TOKEN_ENDPOINT

unset

Optional direct token endpoint override (useful for internal service-to-service calls)

OB_FILE_OIDC_CLIENT_ID

unset

OIDC client identifier used by mcp-plantuml

OB_FILE_OIDC_CLIENT_SECRET

unset

OIDC client secret used by mcp-plantuml

OB_FILE_OIDC_SCOPE

groups

Scope requested during the client-credentials token request

OB_FILE_OIDC_AUDIENCE

ob-file

Audience requested during the client-credentials token request

OB_FILE_OIDC_FORWARDED_PROTO

unset

Optional X-Forwarded-Proto header for internal Authelia calls

OB_FILE_OIDC_FORWARDED_HOST

unset

Optional X-Forwarded-Host header for internal Authelia calls

GENERATED_FILES_DIR

/generated-files

Fallback local/shared-volume directory when OB_FILE_API_BASE_URL is not configured

PUBLIC_FILE_BASE_URL

https://ob-file.fmpn.fr/files

Fallback base URL returned when using shared-volume export

PLANTUML_MCP_SKIP_AUTO_START

unset

When true, skips auto-start so scripts can import the server class without launching transports

When OB_FILE_API_BASE_URL is configured, rendered diagrams are uploaded through ob-file and the MCP response returns the signed download_url generated by ob-file. If OB_FILE_OIDC_DISCOVERY_URL, OB_FILE_OIDC_CLIENT_ID, and OB_FILE_OIDC_CLIENT_SECRET are configured, the server obtains and caches an access token automatically via OAuth 2.0 client credentials. The shared-volume path remains as a compatibility fallback for local/dev setups.


Tools, Prompts & Resources

  • Tools are automatically registered through tools/list. They perform validation, optional auto-fixes, and return structured metadata (success, URLs, markdown snippets, encoded diagram data, and validation errors).

  • Prompts guide the model through PlantUML error handling and provide a ready-made capability landscape template.

  • Resource templates expose onboarding content (resource://plantuml/server-guide) so clients can self-discover usage instructions.


Docker Image

The provided Dockerfile builds the TypeScript sources and produces a minimal runtime image:

docker build -t plantuml-mcp-server .
docker run --rm -e MCP_TRANSPORT=http -p 8765:8765 plantuml-mcp-server

Override environment variables (PLANTUML_SERVER_URL, MCP_API_KEY, etc.) as needed.


Testing & Tooling

  • npm run build โ€“ compile TypeScript

  • npm start โ€“ run using the default HTTP transport

  • npm run start:sse / npm run start:stdio โ€“ convenience scripts

  • npm run test:business-scenario โ€“ snapshot test that converts test_files/generate_sequence_diagram/payload.json into PlantUML and compares it to expected.puml

  • make test-mcp โ€“ smoke-test commands through the mcp CLI


Need Help?

  • Verify connectivity with curl http://<host>:<port>/healthz

  • Confirm auth headers match MCP_API_KEY (Bearer token) if enabled

  • Use the MCP Inspector or Flowise node logs to trace JSON-RPC payloads

The server ships with everything required to operate over HTTP, SSE, and STDIO. Plug in the transport that matches your environment and start generating diagrams!

A
license - permissive license
-
quality - not tested
B
maintenance

Maintenance

โ€“Maintainers
โ€“Response time
โ€“Release cycle
1Releases (12mo)

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/sysam68/plantuml-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server