ultrastealth
Enables Claude to perform stealth browser automation with anti-detection, including navigation, clicking, typing, screenshots, and network monitoring via an MCP server.
README
Ultrastealth
Ultrastealth is a standalone Python package for maximum-stealth browser automation.
It utilizes rebrowser-playwright (with CDP leak fixes), headed Xvfb modes, and several advanced JS bypasses to avoid bot detection systems.
Prerequisites
- Python 3.12+
- Chromium or Google Chrome installed.
Installation
It is recommended to use a virtual environment.
# Create and activate a virtual environment
python3 -m venv venv
source venv/bin/activate
# Install dependencies inside the virtual environment
pip install -r ultrastealth/requirements.txt
Basic Usage
You can use the UltrastealthFetcher in your own scripts:
import asyncio
from ultrastealth import UltrastealthFetcher
async def fetch_example():
# headless=False runs a headed browser (more stealthy, usually combined with Xvfb)
async with UltrastealthFetcher(headless=False) as us:
# fetch_and_evaluate avoids issues with default Playwright page.content() on SPAs
title = await us.fetch_and_evaluate(
url="https://bot.sannysoft.com/",
js_expression="() => document.title",
wait_secs=3.0
)
print("Page Title:", title)
if __name__ == "__main__":
asyncio.run(fetch_example())
Benchmark
bot_benchmark.py scores Ultrastealth against ~15 bot-detection / fingerprint sites
(sannysoft, rebrowser, creepjs, deviceandbrowserinfo, iphey, fingerprint-scan,
cloudflare, …). Run it under a virtual display:
# one-time: start Xvfb on :99 (or use your own display)
Xvfb :99 -screen 0 1920x1080x24 &
DISPLAY=:99 python3 bot_benchmark.py # all sites
DISPLAY=:99 python3 bot_benchmark.py --sites sannysoft rebrowser
python3 bot_benchmark.py --compare bot_benchmark_results.json # reprint table
Each site has its own extraction JS + scorer; results are written to JSON and printed
as a table. Notes: pixelscan/incolumitas only return a verdict from a residential
IP; cloudflare (nowsecure.nl) needs the bundled Turnstile solver. The default
fingerprint is intentionally the consistent real-Chrome one — set
ULTRASTEALTH_BYPASSES=on to additionally layer the (optional) JS spoofs.
MCP Server for Claude Code
The ultrastealth MCP server exposes the stealth browser as tools for Claude Code, giving it the ability to navigate, click, type, screenshot, and monitor network traffic — all with maximum anti-detection.
The server runs as an HTTP service (streamable-http transport) on port 8090 by default, managed by PM2.
Available Tools
Browser automation: browser_navigate, browser_click, browser_type, browser_get_state, browser_screenshot, browser_scroll, browser_go_back, browser_evaluate, browser_press_key, browser_get_html, browser_wait, browser_hover, browser_select_option, browser_close
Tab management: browser_new_tab, browser_list_tabs, browser_switch_tab, browser_close_tab
Network monitoring (Chrome DevTools-style): browser_network_enable, browser_network_disable, browser_network_log, browser_network_detail, browser_network_response_body, browser_network_clear, browser_network_summary
Resource management: browser_status, browser_cleanup, browser_restart
Running the Server
# Start with PM2 (recommended)
pm2 delete ultrastealth-mcp 2>/dev/null
pm2 start /usr/bin/python3 --name "ultrastealth-mcp" \
--cwd /path/to/your/project -- -m ultrastealth.mcp_server --port 8090
# Or run directly
python3 -m ultrastealth.mcp_server # HTTP on 0.0.0.0:8090
python3 -m ultrastealth.mcp_server --port 9000 # HTTP on custom port
python3 -m ultrastealth.mcp_server --transport stdio # stdio mode (legacy)
Connecting Claude Code
The MCP endpoint is http://localhost:8090/mcp (streamable-http).
Project-Level (recommended)
Add to .claude/settings.json in your project root:
{
"mcpServers": {
"ultrastealth": {
"type": "url",
"url": "http://localhost:8090/mcp"
}
}
}
User-Level (all projects)
Add to ~/.claude/settings.json:
{
"mcpServers": {
"ultrastealth": {
"type": "url",
"url": "http://localhost:8090/mcp"
}
}
}
Via CLI
claude mcp add --transport http ultrastealth http://localhost:8090/mcp
Verify
After restarting Claude Code, run /mcp to confirm the ultrastealth server appears and its tools are listed.
Example Workflow
> use ultrastealth to check bot.sannysoft.com
Claude calls: browser_navigate("https://bot.sannysoft.com")
Claude calls: browser_screenshot()
Claude calls: browser_get_html("table")
→ Returns all test results from the page
Network Monitoring Example
> enable network capture and navigate to example.com, then show me all API calls
Claude calls: browser_network_enable()
Claude calls: browser_navigate("https://example.com")
Claude calls: browser_network_log(filter_type="xhr")
→ Returns table of all XHR/fetch requests with status, timing, size
Claude calls: browser_network_detail(request_id=3)
→ Returns full headers and body for a specific request
Included Bypasses
The ultrastealth/bypasses folder includes injected scripts to spoof webgl, mock canvassing, normalize plugins, bypass Runtime.enable, and standard headless fingerprints. These are automatically loaded by the Fetcher.
Driver Fingerprint Patch (patch_rebrowser.py)
rebrowser-playwright's bundled Node driver leaks two identifiers that detectors
(e.g. bot-detector.rebrowser.net) probe for in the page context:
globalThis.__pwInitScripts— the init-script dedup map, created by the driver before any bypass runs (so a JS bypass can't reliably hide it).UtilityScript— the class wrapping everypage.evaluate; its name leaks intoError().stackcaptured by page JS.
patch_rebrowser.py renames both at the driver source (__pwInitScripts → __execGuards,
UtilityScript → ExecutionProxy), consistently so functionality is preserved. This
lifts the rebrowser bot-detector score from 6/10 → 8/10.
python -m ultrastealth.patch_rebrowser # apply
python -m ultrastealth.patch_rebrowser --check # report status
python -m ultrastealth.patch_rebrowser --revert # undo
The patch edits the installed pip package, so a pip install -U rebrowser-playwright
reverts it — re-run the patcher afterward. It is idempotent, revertible, and
upstream-safe: each edit anchors on the original token and warns + skips (never
corrupts) if upstream changed it. UltrastealthFetcher.start() logs a warning if the
patch isn't applied.
Maximum stealth: isolated evaluate (opt-in tradeoff)
The one remaining rebrowser detection — mainWorldExecution — is by design:
rebrowser's default addBinding mode runs page.evaluate in the main world
(detectable). Setting:
export REBROWSER_PATCHES_RUNTIME_FIX_MODE=alwaysIsolated
runs evaluate in an isolated world → 0 positive detections on rebrowser.
Trade-off: isolated evaluate can read the shared DOM (querySelector,
outerHTML, embedded JSON like __NEXT_DATA__ via textContent) but not
main-world JS globals (window.someAppState). Left off by default to avoid
silently breaking scrapers/MCP calls that read main-world JS. Enable it when you
don't need main-world JS access and want the cleanest fingerprint.
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.