burnish-example-server
Provides Chart.js visualizations as a component for rendering tool results, supporting line, bar, and doughnut chart types with configurable JSON settings.
Supports theming via CSS custom properties (--burnish-*), allowing visual customization of components without framework dependencies.
Mentioned as an alternative requiring setup, contrasting with Burnish's zero-config approach for running MCP servers.
Can connect to GitHub MCP servers using personal access tokens, enabling exploration of GitHub tools through the Burnish interface.
Licensed under AGPL-3.0, indicating compliance with GNU Affero General Public License terms.
Provides CDN hosting for Burnish components, allowing import as ES modules without a build step.
Built with Lit 3 web components, providing 10 customizable UI components for rendering MCP tool results.
Supports Markdown formatting in README documentation and component examples.
Compared as an alternative workflow automation tool in the comparison table, noting differences in LLM requirements and visualization capabilities.
Runs as a Node.js CLI tool via npx, enabling local execution and server spawning without installation.
Distributed as an npm package, installable via npx for running MCP servers and exploring their tools.
Described as 'Swagger UI for MCP servers,' providing similar API exploration and documentation capabilities for MCP tool schemas.
Used in SDK integration examples for middleware and schema export functionality.
Quickstart
npx burnish -- npx -y @burnishdev/example-serverThat's it. Burnish spawns the example MCP server, reads its tool list, opens your browser, and renders every tool as an interactive form. The example server ships with a dozen tools — creating bug reports, listing team members, searching records — so you can click through, fill in forms, and see results rendered as cards, tables, and charts without writing a line of your own MCP code.
Want to try it against a different server? Point burnish at any stdio or SSE MCP server — see What you can point it at below.
Try the hosted demo: burnish-demo.fly.dev
Why Burnish?
Zero LLM. No OpenAI key, no Anthropic key, no inference cost. Ever. Explorer mode is 100% deterministic — schemas in, forms out, results rendered.
Zero config. Point
npx burnishat an MCP server command and it runs. No JSON files, no accounts, no Docker.Zero data leaving your machine. The CLI runs locally and talks only to the MCP server you pointed it at. No analytics pixels, no telemetry by default.
Compared to the alternatives
Burnish | MCP Inspector | Composio / Rube | Smithery | n8n | |
Works without LLM | ✅ | ✅ | ❌ | ➖ | ❌ |
Rich visualization | ✅ Cards, tables, charts | ❌ Raw JSON | ➖ Limited | ➖ Registry only | ➖ Node output |
Any MCP server | ✅ | ✅ | ➖ 500 pre-wrapped | ➖ Browse only | ➖ Custom nodes |
Auto-generated forms | ✅ From schema | ❌ Manual JSON | ➖ Pre-built only | ❌ | ➖ Node config UI |
Local / private | ✅ Fully | ✅ | ❌ Cloud | ❌ Cloud | ➖ Self-host (heavy) |
Zero setup | ✅ | ✅ | ❌ Account required | ➖ Browse only | ❌ Docker required |
Composable | ✅ Any server combo | ❌ Single server | ❌ Locked ecosystem | ➖ | ➖ Workflow builder |
✅ Full support · ➖ Partial / limited · ❌ Not supported
What you can point it at
# The Burnish example server — richest default demo
npx burnish -- npx -y @burnishdev/example-server
# Any published stdio MCP server
npx burnish -- npx -y @modelcontextprotocol/server-filesystem /tmp
# GitHub (needs a PAT)
GITHUB_PERSONAL_ACCESS_TOKEN=ghp_... \
npx burnish -- npx -y @modelcontextprotocol/server-github
# An SSE / HTTP MCP server
npx burnish --sse https://your-mcp-server.example.com/sse
# A multi-server config file
npx burnish --config ./mcp-servers.jsonAll configured servers connect at startup. Their tools are available immediately — discoverable, documented, and executable from the browser.
For MCP server owners
Let your users explore your server without cloning anything. Drop this into your README:
[](https://github.com/danfking/burnish)
```bash
npx burnish -- npx @your-org/your-mcp-server
```Want your tool results to render as cards, tables, and charts instead of raw JSON? See the Output Format Guide.
Links
Hosted demo — burnish-demo.fly.dev
Discussions — github.com/danfking/burnish/discussions
Issues — github.com/danfking/burnish/issues
Registries — Smithery, Glama, mcp.so (tracked in #383)
Features
Connect. Browse. Execute. Everything is driven by the server's tool schemas.
Instant tool discovery — every tool listed with its description and input schema
Auto-generated forms — JSON Schema in, interactive form out
Rich results — responses rendered as cards, tables, charts, stat bars, not raw JSON
Fully private — runs locally, no external calls, no telemetry by default
Zero config —
npx burnishand you're runningDrill-down navigation — collapsible sections and session persistence
Framework-agnostic — standard web components, no React/Vue/Angular lock-in
Themeable —
--burnish-*CSS custom propertiesNo build step — import components from CDN as ES modules
Component reference
10 Lit 3 web components, each driven by JSON attributes. Every example below is live in the hosted demo — click "Try it" to open the tool directly.
Component | Preview | Key Attributes | Purpose | Live example |
|
|
| Individual items with drill-down | |
|
|
| Summary metrics / filter pills | |
|
|
| Tabular data with status coloring | |
|
|
| Chart.js visualizations | |
|
|
| Collapsible grouping container | |
|
|
| Single KPI display | |
|
|
| Chat bubbles | |
|
|
| User input / tool execution | |
|
|
| Contextual next-step buttons | |
|
|
| Real-time tool chain visualization |
Status values: success, warning, error, muted, info — mapped to semantic colors via CSS custom properties.
Action types: read (auto-invoke, safe) and write (shows form, requires user confirmation).
SDK integration
Middleware
Add Burnish Explorer to your MCP server with one line:
import { withBurnishUI } from "burnish/middleware";
await withBurnishUI(server, { port: 3001 });Schema export
npx burnish export -- npx @your-org/your-server > schema.jsonUse in your own project
CDN (no build step)
<script type="module"
src="https://esm.sh/@burnishdev/components@0.4.1"></script>
<link rel="stylesheet"
href="https://cdn.jsdelivr.net/npm/@burnishdev/components@0.4.1/src/tokens.css" />
<burnish-card
title="API Gateway"
status="success"
body="All systems operational"
meta='[{"label":"Uptime","value":"99.9%"},{"label":"Latency","value":"42ms"}]'
item-id="api-gw-1">
</burnish-card>npm
npm install @burnishdev/componentsimport '@burnishdev/components';
// Components auto-register with burnish-* prefix.
// Custom prefix:
import { BurnishCard } from '@burnishdev/components';
customElements.define('my-card', class extends BurnishCard {});Renderer
npm install @burnishdev/rendererimport { findStreamElements, appendStreamElement } from '@burnishdev/renderer';
const elements = findStreamElements(chunk);
for (const el of elements) {
appendStreamElement(container, stack, el, safeAttrs, sanitize);
}Configuration
MCP servers
Configure in apps/demo/mcp-servers.json when running from source, or pass --config to the CLI:
{
"mcpServers": {
"example": {
"command": "npx",
"args": ["-y", "@burnishdev/example-server"]
},
"filesystem": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", "/path/to/dir"]
},
"github": {
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-github"],
"env": {
"GITHUB_PERSONAL_ACCESS_TOKEN": "${GITHUB_PERSONAL_ACCESS_TOKEN}"
}
}
}
}All configured servers connect at startup. Their tools are available immediately.
Development
git clone https://github.com/danfking/burnish.git
cd burnish
pnpm install # Install all dependencies
pnpm build # Build all packages
pnpm dev # Start the demo
pnpm test # Run Playwright tests
pnpm clean # Clean all build artifactsburnish/
├── packages/
│ ├── components/ @burnishdev/components — 10 Lit web components
│ ├── renderer/ @burnishdev/renderer — streaming parser + sanitizer
│ ├── app/ @burnishdev/app — drill-down logic + stream orchestration
│ ├── server/ @burnishdev/server — MCP hub + guards + intent resolver
│ ├── example-server/ @burnishdev/example-server — showcase MCP server (34 tools)
│ └── cli/ burnish CLI — npx burnish launcher + middleware
├── apps/
│ └── demo/
│ ├── server/ Hono API
│ └── public/ SPA shell (ES modules, no framework)
└── package.json pnpm workspace rootPrerequisites
Node.js 20+
pnpm 9+
How it works
┌──────────────────────────────────┐
│ MCP Servers │
│ (filesystem, GitHub, DB, ...) │
└──────────────┬───────────────────┘
│ tool calls / results
▼
┌──────────────────────────┐
│ Schema-Driven UI │
│ │
│ • List tools │
│ • Generate forms │
│ • Map results → comps │
└──────────┬───────────────┘
│
▼
┌──────────────────────────┐
│ Streaming Renderer │
│ │
│ • Parse tags on arrival │
│ • Sanitize (DOMPurify) │
│ • Append to DOM │
└──────────┬───────────────┘
│
▼
┌──────────────────────────┐
│ Web Components (Lit 3) │
│ │
│ • Shadow DOM isolation │
│ • JSON attribute parsing│
│ • Event-driven drill- │
│ down navigation │
└──────────────────────────┘Burnish reads the MCP server's tool list, generates forms from JSON Schema, and maps results directly to components — no LLM in the loop. Everything runs locally.
Coming soon: Navigator
Navigator is the planned LLM-powered natural-language layer over Explorer mode — ask a question and Burnish picks the right tools across your connected servers, rendering the answer with the same components you see today. Explorer mode (what you use now) stays free, local, and zero-LLM.
Privacy & Telemetry
Burnish collects opt-in, anonymous telemetry to measure real adoption (see issue #382). It is off by default. On the first interactive run of the CLI you'll see a prompt asking whether to enable it — pressing Enter or anything other than y keeps it off.
What we send (only if you opt in):
v— burnish CLI versionos— OS family:darwin,linux,win32, orothernode— Node.js major versionbucket— coarse invocation-count bucket:1,2-5,6-20, or21+id— a random install ID (UUID) generated once on first opt-inschema_version— payload schema version (currently"1")
What we never send: server URLs, tool names, schemas, arguments, file paths, hostnames, usernames, IP addresses we can see beyond the TCP connection, or any content from your MCP servers. There is no per-tool or per-schema tracking.
How to opt out at any time:
Set the environment variable
BURNISH_TELEMETRY=0(also acceptsfalse,off,no). This overrides any stored choice.Or delete / edit the stored choice file:
macOS / Linux:
~/.config/burnish/telemetry.json(honors$XDG_CONFIG_HOME)Windows:
%APPDATA%\burnish\telemetry.json
Telemetry is a single fire-and-forget HTTPS POST to https://burnish-demo.fly.dev/telemetry/v1/ping with a short timeout. If the endpoint is unreachable, the CLI behaves identically — nothing is retried or queued. Telemetry is skipped entirely in non-interactive and CI environments when no choice has been stored.
License
This server cannot be installed
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/danfking/burnish'
If you have feedback or need assistance with the MCP directory API, please join our Discord server









