mcp-snapshot-filter
A proxy server that intercepts and filters content-heavy responses from chrome-devtools-mcp, reducing token consumption by 40-60% for browser automation tools like Claude Code.
README
mcp-snapshot-filter
MCP proxy that sits between Claude Code and chrome-devtools-mcp, intercepting content-heavy responses and applying smart filtering to reduce token usage by 40-60%.
Claude Code <--stdio--> mcp-snapshot-filter <--stdio--> chrome-devtools-mcp
Why?
Browser MCP tools (especially take_snapshot) return massive accessibility trees that fill up the context window fast. A single snapshot of a data-heavy page can be 30-40KB of text. This proxy transparently filters that down without breaking any tool interactions.
Real-world results:
| Page | Original | Filtered | Reduction |
|---|---|---|---|
| GitHub repo page | 29.5KB | 22.8KB | 23% |
| Portal with 36-row data table | 38.5KB | 17.3KB | 55% |
Setup
# Clone and build
git clone https://github.com/Akarda/mcp-snapshot-filter.git
cd mcp-snapshot-filter
npm install
npm run build
Add to ~/.claude.json (replace any existing chrome-devtools entry):
{
"mcpServers": {
"chrome-devtools": {
"type": "stdio",
"command": "node",
"args": [
"/path/to/mcp-snapshot-filter/dist/index.js",
"--filter-level=moderate",
"--",
"npx", "-y", "chrome-devtools-mcp@latest"
]
}
}
}
Restart Claude Code to pick up the new config.
Filter Levels
| Setting | Light | Moderate (default) | Aggressive |
|---|---|---|---|
| maxNodes | 1000 | 500 | 300 |
| maxDepth | 20 | 15 | 10 |
| maxSimilarSiblings | 5 | 3 | 2 |
| Strip decorative nodes | yes | yes | yes |
| Collapse navigation | no | yes | yes |
| Focus main content only | no | no | yes |
| Est. reduction | 20-30% | 40-60% | 60-80% |
Use --filter-level=off to disable all filtering and pass through raw responses.
What Gets Filtered
Snapshot filtering (biggest impact)
- Decorative nodes removed —
role=none/presentation/separator, empty text nodes, unnamed generic wrappers are stripped (children promoted up) - Similar siblings collapsed — after N consecutive siblings with the same role (e.g., 50
StaticTextnodes in a table), keeps first N and shows... [47 more StaticText elements collapsed] - Navigation collapsed —
navigation/banner/contentinfo/menusubtrees reduced to a single summary:[navigation: 21 items, 9 links] - Main content focus (aggressive only) — when
role=mainexists, sibling subtrees are summarized - Depth/node limits — prunes beyond maxDepth, caps total node count
Network request filtering
Strips image, font, stylesheet (and media in aggressive) entries from list_network_requests output. All xhr, fetch, document requests remain visible. get_network_request is never filtered — individual request details always pass through in full.
Console message filtering
Strips debug, verbose (and dir, trace at higher levels) from list_console_messages. Error and warning messages are always preserved.
Evaluate script & memory snapshot filtering
Large responses from evaluate_script and take_memory_snapshot are truncated:
- JSON arrays — kept to first N items (100/30/10 depending on level)
- HTML dumps — truncated at max text length
- Plain text — truncated at max text length (100KB/50KB/20KB depending on level)
What Is NOT Filtered
- Error responses — always passed through raw
- Image content blocks — screenshots etc. are never touched
- Unknown/new tools — only explicitly listed tools get filtered, everything else passes through
- Individual request/message details —
get_network_request,get_console_messageare unfiltered - Non-interactive tools —
emulate,performance_*,screencast_*, etc. pass through as-is
UID Integrity
All UIDs of visible nodes are preserved in filtered output. After taking a filtered snapshot, you can click, fill, or hover any UID shown in the output — the proxy forwards these calls to the upstream server unchanged.
Session Stats
Each filtered response includes a stats line:
[cdp-filter-proxy: 20.7KB saved (55%) | session: 22.4KB saved across 2 calls (52%)]
How It Works
The proxy uses the MCP SDK's low-level Server class (not McpServer) to avoid JSON Schema to Zod conversion issues when proxying tool definitions. On startup it:
- Spawns the upstream
chrome-devtools-mcpas a subprocess viaStdioClientTransport - Discovers all upstream tools via
listTools() - Re-exposes them via
setRequestHandler(ListToolsRequestSchema)andsetRequestHandler(CallToolRequestSchema) - For calls to content-heavy tools, parses the response text into markdown sections (
## Latest page snapshot, etc.), applies the appropriate filter to each section, and returns the filtered result
Compatibility with --slim mode
chrome-devtools-mcp supports a --slim flag that reduces the server to just 3 tools (navigate, evaluate, screenshot) for maximum token savings (~368 tokens). If the proxy detects --slim in the upstream args, it will warn that filtering has no effect — slim mode responses are already minimal. The proxy is designed for full mode where it preserves all tools while reducing response sizes by 40-60%.
Development
npm run build # compile TypeScript to dist/
After rebuilding, restart Claude Code to pick up changes (MCP servers are long-lived processes).
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.