A defensive, token-aware MCP server for Dune Analytics.
Project description
Dune MCP (Model Context Protocol)
A defensive, token-aware MCP server for Dune Analytics.
This project enables LLMs (like Claude, or custom agents) to securely interact with Dune Analytics. It acts as a "Smart Gateway" that prioritizes Query Reuse and Budget Safety over raw SQL generation, protecting your API credits and reducing token consumption.
Quick Start
-
Get your API Keys:
- Dune API Key: Get it here
- GitHub Token (Optional): Get it here (Select
public_reposcope)
-
Install & Configure:
# Clone the repo git clone https://github.com/nice-bills/dune-mcp.git cd dune-mcp # Install dependencies (requires uv) # If you don't have uv: pip install uv uv sync # Set up environment cp .env.example .env # Open .env and paste your keys
-
Connect to Claude: Add this to your
claude_desktop_config.json:- MacOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
{ "mcpServers": { "dune": { "command": "uv", "args": ["run", "src/main.py"], "cwd": "/absolute/path/to/dune-mcp" } } }
(Note: Replace
/absolute/path/to/with the actual path to the folder) - MacOS:
Features
- Google-like Search: Reverse-engineered GraphQL integration allows searching public queries by keyword (e.g., "uniswap volume").
- Portfolio Browsing: List queries by user handle to access your own or others' work.
- Budget Manager: Deterministic guards that prevent credit exhaustion.
- Token-Optimized: Returns "Indices" (summaries) instead of raw schemas. Results are previewed (top 5 rows), not streamed in full.
- Query Reuse First: Tools encourage searching existing community queries before generating new SQL.
- CSV Export: "Escape hatch" to download full datasets to disk instead of flooding the LLM context.
Toolset
search_public_queries(query): Search existing queries by keyword (free & fast).list_user_queries(handle, limit): List queries by user (e.g., "bils").search_spellbook(keyword): Search the official Dune Spellbook GitHub repo for tables (e.g., "uniswap").get_spellbook_file_content(path): View the SQL or schema of a Spellbook file.get_query_details(query_id): Inspect SQL and parameters (on demand).get_table_schema(table_name): Get columns for a specific table (Costs Credits).execute_query(query_id): Run a query (async, budget-checked).get_job_status(job_id): Poll for completion.get_job_results_summary(job_id): Get a lightweight preview (5 rows + stats).export_results_to_csv(job_id): Download the full dataset.analyze_results(job_id): Detect outliers and trends in data.analyze_query_error(error_message, query_sql): Get AI-driven fix suggestions for failed queries.
Installation
This project uses uv for fast package management.
# 1. Clone the repo
git clone https://github.com/nice-bills/dune-mcp.git
cd dune-mcp
# 2. Setup config
cp .env.example .env
# Edit .env and add your DUNE_API_KEY
Configuration
Add your handle to .env to allow the MCP to auto-detect your queries:
DUNE_API_KEY=your_key
DUNE_USER_HANDLE=your_username # Optional
Usage
Option 1: Claude Desktop
Add this to your claude_desktop_config.json:
{
"mcpServers": {
"dune": {
"command": "uv",
"args": ["run", "-m", "src.main", "--directory", "/path/to/dune-mcp"]
}
}
}
Option 2: MCP Inspector (Web UI)
Test the tools interactively in your browser.
npx @modelcontextprotocol/inspector uv run -m src.main
Best Practices
Zero-Credit Schema Discovery
To find table names or column structures without consuming Dune credits:
- Use
search_spellbook("keyword")to find official Dune Spellbook models (SQL files) and schema definitions (schema.yml) that match your topic. - Use
get_spellbook_file_content("path/to/file.sql")to view the SQL or schema definition. This directly gives you the table name and its structure. - Alternatively, use
search_public_queries("topic")to find existing queries on the topic. - Use
get_query_details(id)to inspect their SQL. - Extract the table names (e.g.,
uniswap_v3_ethereum.Factory_evt_PoolCreated) from the SQL.
This "Rosetta Stone" approach is faster, safer, and cheaper than blindly querying the schema.
Safety Principles
- Never stream raw data: 100k rows = Token Death. We stream previews + stats.
- Two-Phase Reasoning: Plan (Search/Estimate) → Execute.
- MCP Does the Boring Work: We calculate min/max/avg in Python, not the LLM.
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dune_mcp-0.1.0.tar.gz.
File metadata
- Download URL: dune_mcp-0.1.0.tar.gz
- Upload date:
- Size: 111.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
905f844f694f8175d1cc6dda6aece66b208925c76d6320e8b6454e22b6462ea0
|
|
| MD5 |
5fc60f42c883d8b68cdd179ec17b1ed6
|
|
| BLAKE2b-256 |
a9071803e63aafc27e91a8665d7d2284b4f55e4fe12a8d53ee0eb449bcb18724
|
File details
Details for the file dune_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: dune_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 17.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
51b68efd552c6e494a8d15691da5cfc19702927a219d83f03e9f629148743f24
|
|
| MD5 |
19d2bda105d9851a8bf38d9dc02f3749
|
|
| BLAKE2b-256 |
4b6b763f3cd68f903af256d6e616e3a49ed510b66448c707f31a6f4c0da80d43
|