Allows for the programmatic management of Apache Superset dashboards and charts, dataset schema exploration, and the execution of SQL queries directly against connected databases.
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., "@Superset MCP ServerCreate a bar chart for sales_data showing revenue per month"
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.
π Superset MCP Server (Streamable HTTP)
MCP (Model Context Protocol) Server untuk Apache Superset yang memungkinkan integrasi chatbot dengan Superset untuk membuat dashboard, chart, dan mengeksekusi query SQL secara programatis.
β¨ Fitur
π Dashboard Management - List, get, create dashboard dan tambahkan chart ke dashboard
π Chart Management - List, get, create chart dengan auto-detection schema
ποΈ Dataset Management - List datasets dan get schema kolom
π SQL Execution - Eksekusi query SQL langsung ke database Superset
π Stateless HTTP - Menggunakan Streamable HTTP transport untuk kompatibilitas dengan Open WebUI
π Auto Authentication - Otomatis login dan refresh token ke Superset
π οΈ Teknologi
Runtime: Node.js + TypeScript
Transport: Express.js + JSON-RPC 2.0
Protocol: MCP (Model Context Protocol)
Client: Axios untuk HTTP requests
π Prasyarat
Node.js v18 atau lebih baru
Apache Superset yang sudah running
NPM atau Yarn
β‘ Quick Start
1. Clone & Install Dependencies
git clone <repository-url>
cd superset-mcp
npm install2. Konfigurasi Environment
Salin file .env.example ke .env dan sesuaikan konfigurasinya:
cp .env.example .envIsi konfigurasi di file .env:
# Superset Configuration
SUPERSET_URL=http://localhost:8088
SUPERSET_USERNAME=admin
SUPERSET_PASSWORD=admin
# MCP Server Configuration
MCP_PORT=30003. Build & Run
# Build TypeScript
npm run build
# Jalankan server
npm startAtau untuk development dengan hot-reload:
npm run dev4. Verifikasi Server
Akses health check endpoint:
curl http://localhost:3000/healthResponse yang diharapkan:
{
"status": "ok",
"server": "superset-mcp",
"version": "1.0.0",
"mode": "stateless",
"tools": ["list_dashboards", "get_dashboard", "create_dashboard", ...]
}π Integrasi dengan Open WebUI
Konfigurasi di Open WebUI
Buka Admin Panel β Tools β Tool Connections
Tambahkan MCP Server baru:
Name: Superset MCP
Type: MCP (Streamable HTTP)
URL:
http://YOUR_SERVER_IP:3000/mcp
Save dan test koneksi
π§ Available Tools
Dashboard Tools
Tool | Deskripsi |
| Mendapatkan semua dashboard yang tersedia |
| Detail dashboard termasuk chart-chart di dalamnya |
| Membuat dashboard baru |
| Menambahkan satu chart ke dashboard |
| Menambahkan multiple charts ke dashboard (recommended) |
Chart Tools
Tool | Deskripsi |
| Mendapatkan semua chart yang tersedia |
| Detail konfigurasi chart |
| Fetch data dari chart |
| Membuat chart baru (manual config) |
| Membuat chart dengan auto-detection schema |
Dataset Tools
Tool | Deskripsi |
| Mendapatkan semua datasets/tables |
| Mendapatkan definisi kolom dari dataset |
SQL Tools
Tool | Deskripsi |
| Mendapatkan semua koneksi database |
| Eksekusi query SQL ke database |
π Contoh Penggunaan
Membuat Chart dengan Auto-Detection
"Buatkan bar chart untuk dataset sales_data yang menampilkan total revenue per bulan"AI akan menggunakan create_chart_auto untuk:
Menganalisis schema dataset
Mendeteksi kolom waktu (x_axis)
Mendeteksi kolom numeric untuk metrics
Membuat chart dengan konfigurasi optimal
Membuat Dashboard dengan Multiple Charts
"Buatkan dashboard Sales Overview dengan 3 chart: line chart revenue, pie chart by category, dan table top products"AI akan:
create_dashboard- Membuat dashboard barucreate_chart_auto(3x) - Membuat setiap chartadd_charts_to_dashboard- Menambahkan semua chart sekaligus dengan layout optimal
ποΈ Struktur Project
superset-mcp/
βββ src/
β βββ index.ts # Entry point
β βββ server.ts # Express server & MCP tools
β βββ superset-client.ts # Superset API client
βββ dist/ # Compiled JavaScript
βββ .env # Environment variables
βββ .env.example # Example environment
βββ package.json
βββ tsconfig.json
βββ README.mdπ API Endpoints
Endpoint | Method | Deskripsi |
| GET | Health check |
| POST | MCP JSON-RPC requests |
| GET | SSE streaming (keepalive) |
| DELETE | Session cleanup |
βοΈ Environment Variables
Variable | Default | Deskripsi |
|
| URL Superset instance |
|
| Username untuk login |
|
| Password untuk login |
|
| Port untuk MCP server |
π Troubleshooting
1. Authentication Failed
Pastikan credentials di .env sudah benar. Server akan otomatis refresh token jika expired.
2. CORS Error
Server sudah dikonfigurasi untuk menerima requests dari semua origin. Jika masih error, pastikan firewall tidak memblokir port.
3. Chart Tidak Menampilkan Data
Gunakan create_chart_auto daripada create_chart untuk auto-detection metrics dan dimensions.
π License
MIT License
π€ Contributing
Contributions are welcome! Feel free to open issues atau pull requests.