| name | camoufox-cli |
| description | Anti-detect browser automation CLI & Skills for AI agents. Use when the user needs to interact with websites with bot detection, CAPTCHAs, or anti-bot blocks, including navigating pages, filling forms, clicking buttons, taking screenshots, extracting data, testing web apps, or automating any browser task that requires bypassing fingerprint checks. |
Anti-Detect Browser Automation with camoufox-cli
What Makes This Different
camoufox-cli is built on Camoufox (anti-detect Firefox) with C++-level fingerprint spoofing:
navigator.webdriver = false
- Real browser plugins, randomized canvas/WebGL/audio fingerprints
- Real Firefox UA string -- passes bot detection on sites that block Chromium automation
Use camoufox-cli whenever you need to drive a real browser — it's the default browser tool in this sandbox.
Core Workflow
Every browser automation follows this pattern:
- Navigate:
camoufox-cli open <url>
- Snapshot:
camoufox-cli snapshot -i (get element refs like @e1, @e2)
- Interact: Use refs to click, fill, select
- Re-snapshot: After navigation or DOM changes, get fresh refs
- Close:
camoufox-cli close (close the browser when the entire task is fully complete; keep it open if the user may have follow-up instructions)
camoufox-cli open https://example.com/form
camoufox-cli snapshot -i
camoufox-cli fill @e1 "user@example.com"
camoufox-cli fill @e2 "password123"
camoufox-cli click @e3
camoufox-cli snapshot -i
Command Chaining
Commands can be chained with && in a single shell invocation. The browser persists between commands via a background daemon, so chaining is safe and more efficient than separate calls.
camoufox-cli open https://example.com && camoufox-cli snapshot -i
camoufox-cli fill @e1 "user@example.com" && camoufox-cli fill @e2 "password123" && camoufox-cli click @e3
camoufox-cli open https://example.com && camoufox-cli screenshot page.png
When to chain: Use && when you don't need to read the output of an intermediate command before proceeding (e.g., open + screenshot). Run commands separately when you need to parse the output first (e.g., snapshot to discover refs, then interact using those refs).
Essential Commands
camoufox-cli open <url>
camoufox-cli back
camoufox-cli forward
camoufox-cli reload
camoufox-cli url
camoufox-cli title
camoufox-cli close
camoufox-cli close --all
camoufox-cli snapshot
camoufox-cli snapshot -i
camoufox-cli snapshot -s "#selector"
camoufox-cli click @e1
camoufox-cli fill @e1 "text"
camoufox-cli type @e1 "text"
camoufox-cli select @e1 "option"
camoufox-cli check @e1
camoufox-cli hover @e1
camoufox-cli press Enter
camoufox-cli press "Control+a"
camoufox-cli text @e1
camoufox-cli text body
camoufox-cli eval "document.title"
camoufox-cli screenshot
camoufox-cli screenshot page.png
camoufox-cli screenshot --full p.png
camoufox-cli pdf output.pdf
camoufox-cli scroll down
camoufox-cli scroll up
camoufox-cli scroll down 1000
camoufox-cli wait @e1
camoufox-cli wait 2000
camoufox-cli wait --url "*/dashboard"
camoufox-cli tabs
camoufox-cli switch 2
camoufox-cli close-tab
camoufox-cli cookies
camoufox-cli cookies import file.json
camoufox-cli cookies export file.json
camoufox-cli sessions
camoufox-cli --session work open <url>
camoufox-cli close --all
camoufox-cli install
camoufox-cli install --with-deps
Common Patterns
Form Submission
camoufox-cli open https://example.com/signup
camoufox-cli snapshot -i
camoufox-cli fill @e1 "Jane Doe"
camoufox-cli fill @e2 "jane@example.com"
camoufox-cli select @e3 "California"
camoufox-cli check @e4
camoufox-cli click @e5
camoufox-cli snapshot -i
Data Extraction
camoufox-cli open https://example.com/products
camoufox-cli snapshot -i
camoufox-cli text @e5
camoufox-cli eval "document.title"
camoufox-cli screenshot results.png
Cookie Management (Persist Login)
camoufox-cli open https://app.example.com/login
camoufox-cli snapshot -i
camoufox-cli fill @e1 "user"
camoufox-cli fill @e2 "pass"
camoufox-cli click @e3
camoufox-cli cookies export auth.json
camoufox-cli open https://app.example.com
camoufox-cli cookies import auth.json
camoufox-cli reload
For long-lived accounts where the site also verifies device stability (not just the cookie), combine this with --persistent so the fingerprint stays fixed alongside the cookies — see the Persistent Identity section below.
Multiple Tabs
camoufox-cli open https://site-a.com
camoufox-cli eval "window.open('https://site-b.com')"
camoufox-cli tabs
camoufox-cli switch 1
camoufox-cli snapshot -i
Parallel Sessions
camoufox-cli --session s1 open https://site-a.com
camoufox-cli --session s2 open https://site-b.com
camoufox-cli sessions
camoufox-cli --session s1 snapshot -i
camoufox-cli --session s2 snapshot -i
Visual Browser (Debugging)
camoufox-cli --headed open https://example.com
camoufox-cli snapshot -i
camoufox-cli screenshot debug.png
Session Management and Cleanup
When running multiple agents or automations concurrently, always use named sessions to avoid conflicts:
camoufox-cli --session agent1 open https://site-a.com
camoufox-cli --session agent2 open https://site-b.com
camoufox-cli sessions
Always close your browser session when done to avoid leaked processes:
camoufox-cli close
camoufox-cli --session agent1 close
camoufox-cli close --all
If a previous session was not closed properly, the daemon may still be running. Use camoufox-cli close to clean it up before starting new work.
JS-Heavy Sites (Google Maps, SPAs)
Single-page apps render their content via JavaScript — the visible business listing, the address, the phone number, the reviews. The DOM text node body is the application bundle, not the rendered UI.
Use snapshot (not text body) on these sites. The aria tree exposes the rendered, accessible labels:
camoufox-cli open "https://www.google.com/maps/search/insurance+agent+austin+tx/"
camoufox-cli snapshot -i
camoufox-cli text body
If snapshot shows the page hasn't finished rendering, wait for a known element (e.g. the listing heading) and re-snapshot.
Timeouts and Cold-Start Cost
First call may take 2-3 minutes. Spinning up the headless Firefox daemon — especially through a proxy where GeoIP lookup adds latency — is slow. Once the daemon is up, subsequent calls in the same session are sub-second. Set timeout: 180 (or higher) on the exec call that runs your first camoufox-cli open so the agent doesn't kill the daemon mid-bring-up:
{"command": "camoufox-cli open https://example.com && camoufox-cli snapshot -i", "timeout": 180}
{"command": "camoufox-cli click @e5 && camoufox-cli snapshot -i"}
Timeouts and Slow Pages
Some pages take time to fully load, especially those with dynamic content or heavy JavaScript. Use explicit waits before taking a snapshot:
camoufox-cli wait @e1
camoufox-cli snapshot -i
camoufox-cli wait --url "*/dashboard"
camoufox-cli snapshot -i
camoufox-cli wait 3000
camoufox-cli snapshot -i
When dealing with slow pages, always wait before snapshotting. If you snapshot too early, elements may be missing from the output.
Ref Lifecycle (Important)
Refs (@e1, @e2, etc.) are temporary identifiers assigned by sequential numbering during each snapshot. They are invalidated when the page changes.
Always re-snapshot after:
- Clicking links or buttons that navigate
- Form submissions
- Dynamic content loading (dropdowns, modals, lazy-loaded content)
- Scrolling that triggers new content
camoufox-cli click @e5
camoufox-cli snapshot -i
camoufox-cli click @e1
camoufox-cli click @e1
camoufox-cli snapshot -i
camoufox-cli click @e7
camoufox-cli open https://example.com
camoufox-cli click @e1
camoufox-cli click @e5
camoufox-cli click @e3
Always take a fresh snapshot before interacting with elements after navigation or page changes.
Troubleshooting
"Ref @eN not found"
The ref was invalidated. Re-snapshot to get fresh refs:
camoufox-cli snapshot -i
Element Not Visible in Snapshot
camoufox-cli scroll down 1000
camoufox-cli snapshot -i
camoufox-cli wait 2000
camoufox-cli snapshot -i
Too Many Elements in Snapshot
camoufox-cli snapshot -s "#main-content"
camoufox-cli snapshot -i -s "form.login"
Page Not Fully Loaded
camoufox-cli wait --url "*/dashboard"
camoufox-cli snapshot -i
camoufox-cli wait 3000
camoufox-cli snapshot -i
Global Flags
--session <name> Named session (default: "default")
--headed Show browser window (default: headless)
--timeout <seconds> Daemon idle timeout (default: 1800)
--json Output as JSON instead of human-readable
--persistent [path] Persistent identity — reuse the same fingerprint + cookies across launches
(default path: ~/.camoufox-cli/profiles/<session>)
--proxy <url> Proxy server (http:// or https://; auth: http://user:pass@host:port)
--no-geoip Disable automatic GeoIP spoofing (auto-enabled with --proxy)
--locale <tag> Force browser locale (e.g. "en-US" or "en-US,zh-CN")
Persistent Identity
By default, every launch gets a fresh random fingerprint. Add --persistent [path] to reuse the same fingerprint + cookies across launches — fingerprint/OS/canvas+font seeds are frozen on first launch (delete the directory to reset); --locale and proxy-derived timezone/geolocation are stored but refreshed whenever you pass the flag; --proxy / --no-geoip are never stored, so pass them every launch.
Use it when the same device should see the same fingerprint across visits (account-bound tasks, parallel independent identities, or when cookies import/export alone isn't enough because the site also checks device stability). Skip it for one-off scraping or quick debugging.
camoufox-cli --session a --persistent ~/.camoufox-cli/profiles/alice open https://app.example.com
camoufox-cli --session b --persistent ~/.camoufox-cli/profiles/bob open https://app.example.com
rm -rf ~/.camoufox-cli/profiles/alice
Documentation