A Python MCP (Model Context Protocol) server providing full browser automation with Camoufox anti-detection capabilities.
- 21 browser automation tools for complete browser control
- Anti-detection: Automatic fingerprint randomization to avoid bot detection
- Lazy initialization: Browser only launches on first tool call
- Persistent sessions: Browser persists between tool calls
- Tab management: Support for multiple tabs/pages
- Form automation: Fill forms, upload files, handle dialogs
uvx camoufox-mcppipx run camoufox-mcppip install camoufox-mcp
camoufox-mcp# Clone the repository
git clone https://github.com/rlgrpe/camoufox-mcp-python.git
cd camoufox-mcp-python
# Install with uv
uv syncAfter installing the package, you need to download the Camoufox browser binary. The command depends on how you installed the package:
uvx camoufox fetchpipx run camoufox fetch# macOS
python3 -m camoufox fetch
# Linux
python -m camoufox fetch
# Windows
camoufox fetchuv run python -m camoufox fetchOn Linux, you also need to install system dependencies:
# Ubuntu/Debian
sudo apt install -y libgtk-3-0 libx11-xcb1 libasound2
# Arch
sudo pacman -S gtk3 libx11 libxcb cairo libasound alsa-lib# Use the same method as installation:
uvx camoufox remove # if using uvx
pipx run camoufox remove # if using pipx
camoufox remove # if using pip
uv run python -m camoufox remove # if using uv from source# Using uvx (recommended)
uvx camoufox-mcp
# Using uv (from source)
uv run camoufox-mcp
# Or as a module
python -m camoufox_mcpclaude mcp add camoufox-mcp -- uvx camoufox-mcpAdd to your Claude Desktop config file:
{
"mcpServers": {
"camoufox-mcp": {
"command": "uvx",
"args": ["camoufox-mcp"]
}
}
}Or if running from source:
{
"mcpServers": {
"camoufox-mcp": {
"command": "uv",
"args": [
"run",
"--directory",
"/path/to/camoufox-mcp-python",
"camoufox-mcp"
]
}
}
}| Tool | Description |
|---|---|
browser_navigate |
Navigate to a URL |
browser_navigate_back |
Go back to the previous page |
browser_snapshot |
Capture accessibility snapshot of the current page |
browser_wait_for |
Wait for text to appear/disappear or a specified time |
| Tool | Description |
|---|---|
browser_click |
Click on an element |
browser_type |
Type text into an element |
browser_hover |
Hover over an element |
browser_drag |
Drag and drop between two elements |
browser_press_key |
Press a key on the keyboard |
browser_select_option |
Select an option in a dropdown |
| Tool | Description |
|---|---|
browser_evaluate |
Evaluate JavaScript on the page or element |
browser_console_messages |
Get console messages |
browser_network_requests |
Get network requests |
browser_take_screenshot |
Take a screenshot |
| Tool | Description |
|---|---|
browser_fill_form |
Fill multiple form fields |
browser_file_upload |
Upload files |
browser_handle_dialog |
Handle dialogs (alert, confirm, prompt) |
| Tool | Description |
|---|---|
browser_tabs |
List, create, close, or select tabs |
browser_resize |
Resize the browser window |
browser_close |
Close the browser |
browser_install |
Install Camoufox browser |
The browser can be configured via the BrowserConfig class in camoufox_mcp/config.py. Available options:
| Parameter | Type | Default | Description |
|---|---|---|---|
os |
str | None | OS to spoof (windows/macos/linux) |
headless |
bool/str | False | Headless mode (or 'virtual') |
humanize |
bool/float | True | Human-like cursor movements |
geoip |
bool | True | Auto-detect geolocation from IP |
proxy |
str/dict | None | Proxy configuration |
block_webrtc |
bool | True | Block WebRTC leaks |
block_webgl |
bool | False | Block WebGL fingerprinting |
block_images |
bool | False | Block image loading |
locale |
str | None | Browser locale |
viewport |
dict | None | Viewport dimensions |
enable_cache |
bool | True | Enable caching |
timeout |
int | 30000 | Page load timeout (ms) |
wait_strategy |
str | "domcontentloaded" | Wait strategy |
ublock |
bool | False | Enable uBlock Origin |
proxy = {
'server': 'http://proxy.example.com:8080',
'username': 'user',
'password': 'pass'
}# Install dev dependencies
uv sync --dev
# Run tests
uv run pytest
# Format code
uv run ruff format
# Lint
uv run ruff checkMIT License - see LICENSE for details.