ultrastealth
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., "@ultrastealthNavigate to bot.sannysoft.com and take a screenshot"
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.
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.
Related MCP server: Browser Agent MCP
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.txtBasic 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 tableEach 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/mcpVerify
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 pageNetwork 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 requestIncluded 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 # undoThe 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=alwaysIsolatedruns 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.
This server cannot be installed
Maintenance
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/anusoft/ultrastealth'
If you have feedback or need assistance with the MCP directory API, please join our Discord server