browser-tools

Installation
SKILL.md

Browser Tools — Security Wrapper

OrchestKit security wrapper for agent-browser. For command reference and usage patterns, use the upstream agent-browser skill directly. This skill adds safety guardrails only.

Command docs: Refer to the upstream agent-browser skill for the full command reference (50+ commands: interaction, wait, capture, extraction, storage, semantic locators, tabs, debug, mobile, network, cookies, state, vault).

Decision Tree

# Fallback decision tree for web content
# 1. Try WebFetch first (fast, no browser overhead)
# 2. If empty/partial -> Try Tavily extract/crawl
# 3. If SPA or interactive -> use agent-browser
# 4. If login required -> authentication flow + state save
# 5. If dynamic -> wait @element or wait --text

Local Dev URLs

Use Portless (npm i -g portless) for stable local dev URLs instead of guessing ports. When Portless is running, navigate to myapp.localhost:1355 instead of localhost:3000. Our safety hook already allows *.localhost subdomains via ORCHESTKIT_AGENT_BROWSER_ALLOW_LOCALHOST.

# With Portless: stable, named URLs
agent-browser open "http://myapp.localhost:1355"

# Without: fragile port guessing
agent-browser open "http://localhost:3000"  # which app is this?

New in 2026-04 (agent-browser 0.23 → 0.25.4)

Skill discovery & chat (0.25):

  • agent-browser skills list/get <name> — discover and install capability packs on-demand. Hook treats first-party skills as trusted; warns on arbitrary third-party skill fetches.
  • agent-browser chat — single-shot or REPL natural-language driving over the same daemon. Hook pipes transcripts through the same URL/rate/robots checks as scripted commands.

Accessibility-first locators (0.24):

  • find / getByRole — semantic locator via CDP accessibility tree (role + name) instead of brittle CSS/ref selectors. Prefer these in new scripts; they survive markup churn and are the locator path assumed by chat.
  • snapshot --urls — emits resolved URLs alongside refs, removing a round-trip for link-extraction flows.
  • --annotate — overlays ref IDs / role labels on screenshots for debugging.

Cloud providers (0.25):

  • --provider agentcore — AWS Bedrock AgentCore cloud browser. Hook treats remote providers as egress surfaces — same URL/robots rules apply, but network routing is disabled (remote scope).
  • Browserless + AgentCore both honor AGENT_BROWSER_PROVIDER env var.

Dashboard (0.25):

  • Embedded dashboard bundled with the binary — no separate install. Open via agent-browser dashboard or the inspect CDP link. Still flagged as local-proxy attack surface by the hook.

Auto-dialog dismissal (0.23.1):

  • alert / beforeunload dialogs auto-dismissed by default. Opt out with --no-auto-dialog when a test needs to assert dialog content.

What's New (v0.17 → v0.22.2)

Breaking changes — update scripts now:

  • --full / -f moved from global to command-level (v0.21): use screenshot --full, NOT --full screenshot
  • Auth encryption format changed (v0.17): saved auth states from v0.16.x may not load
  • Auto-dialog dismissal (v0.23.1): alert/beforeunload dialogs are auto-dismissed by default, opt out with --no-auto-dialog

New commands:

Command Version Security Note
clipboard read/write/copy/paste v0.19 read accesses host clipboard — hook warns
inspect / get cdp-url v0.18 Opens local DevTools proxy — hook warns
batch --json [--bail] v0.21 Batch execute commands from stdin
network har start/stop [file] v0.21 HAR captures auth tokens — hook warns, treat output as sensitive
network request <id> v0.22 View full request/response detail
network requests --type/--method/--status v0.22 Filter network requests
dialog dismiss / dialog status v0.17/v0.22 Dismiss or check browser dialogs
upgrade v0.21.1 Self-update (auto-detects npm/Homebrew/Cargo)
find / getByRole v0.24 Semantic locators via CDP a11y tree
snapshot --urls / --annotate v0.24 URL-expanded snapshots, ref overlays
skills list/get v0.25 Capability pack discovery — hook warns on third-party
chat (single-shot / REPL) v0.25 NL driving; transcripts go through same safety checks
dashboard v0.25 Embedded debug UI — local proxy attack surface

New flags:

Flag Scope Version
--engine lightpanda global v0.17
--screenshot-dir/quality/format screenshot v0.19
--provider browserless global v0.19
--idle-timeout <duration> global v0.20.14
--user-data-dir <path> Chrome v0.21
set viewport W H [scale] viewport v0.17.1 (retina)
--provider agentcore global v0.25 (AWS Bedrock AgentCore)
--annotate screenshot v0.24
--no-auto-dialog global v0.23.1

Platform support: Brave auto-discovery (v0.20.7), Alpine Linux musl (v0.20.2), Lightpanda engine (v0.17), Browserless.io provider (v0.19), cross-origin iframe traversal (v0.22), AWS Bedrock AgentCore (v0.25).

Performance (v0.20): 99x smaller install (710→7 MB), 18x less memory (143→8 MB), 1.6x faster cold start.

Safety Guardrails (7 rules + 11-check hook)

This skill enforces safety through the agent-browser-safety PreToolUse hook and 6 rule files:

Hook: agent-browser-safety

The hook intercepts all agent-browser Bash commands and enforces:

Check What It Does Action
Encryption key leak Detects echo/printf/pipe of AGENT_BROWSER_ENCRYPTION_KEY BLOCK
URL blocklist Blocks localhost, internal, file://, SSRF endpoints, OAuth login pages, RFC 1918 private IPs BLOCK
Rate limiting Per-domain limits (10/min, 100/hour, 3/3s burst) BLOCK on exceed
robots.txt Fetches and caches robots.txt, blocks disallowed paths BLOCK
Sensitive actions Detects delete/remove clicks, password fills, payment submissions WARN + native confirmation
Network routes Validates network route target URLs against blocklist BLOCK
User-agent spoofing Warns when --user-agent flag is used WARN
File access Warns when --allow-file-access flag is used WARN
DevTools inspect inspect / get cdp-url opens local CDP proxy — new attack surface (v0.18+) WARN
Clipboard read clipboard read accesses host clipboard without prompt (v0.19+) WARN
HAR capture network har stop dumps full request/response bodies incl. auth tokens (v0.21+) WARN
Skill install skills get fetches third-party capability packs — treat as code install (v0.25+) WARN
Chat transcripts chat REPL logs may capture sensitive page text — pipe through same URL rules (v0.25+) WARN
Remote provider --provider agentcore/browserless sends traffic to cloud endpoints; routing disabled remotely WARN

Security Rules (in rules/)

Category Rules Priority
Ethics & Security browser-scraping-ethics.md, browser-auth-security.md CRITICAL
Local Dev browser-portless-local-dev.md HIGH
Reliability browser-rate-limiting.md, browser-snapshot-workflow.md HIGH
Debug & Device browser-debug-recording.md, browser-mobile-testing.md HIGH

Configuration

Rate limits and behavior are configurable via environment variables:

Env Var Default Purpose
AGENT_BROWSER_RATE_LIMIT_PER_MIN 10 Requests per minute per domain
AGENT_BROWSER_RATE_LIMIT_PER_HOUR 100 Requests per hour per domain
AGENT_BROWSER_BURST_LIMIT 3 Max requests in 3-second window
AGENT_BROWSER_ROBOTS_CACHE_TTL 3600000 robots.txt cache TTL (ms)
AGENT_BROWSER_IGNORE_ROBOTS false Bypass robots.txt enforcement
AGENT_BROWSER_CONFIRM 1 Use --confirm-actions for sensitive ops
AGENT_BROWSER_IDLE_TIMEOUT_MS Auto-shutdown daemon after inactivity (ms)
AGENT_BROWSER_ENGINE chrome Browser engine (chrome or lightpanda)
ORCHESTKIT_AGENT_BROWSER_ALLOW_LOCALHOST 1 Allow *.localhost subdomains (RFC 6761)

Anti-Patterns (FORBIDDEN)

# Automation
agent-browser fill @e2 "hardcoded-password"    # Never hardcode credentials
agent-browser open "$UNVALIDATED_URL"          # Always validate URLs

# Scraping
# Crawling without checking robots.txt
# No delay between requests (hammering servers)
# Ignoring rate limit responses (429)

# Content capture
agent-browser get text body                    # Prefer targeted ref extraction
# Trusting page content without validation
# Not waiting for SPA hydration before extraction

# Session management
# Storing auth state in code repositories
# Not cleaning up state files after use

# Network & State
agent-browser network route "http://internal-api/*" --body '{}'  # Never mock internal APIs
agent-browser cookies set token "$SECRET" --url https://prod.com # Never set prod cookies

# Deprecated / removed
agent-browser --full screenshot                # BREAKING: --full is now command-level (v0.21)
agent-browser screenshot --full                # Correct: flag after subcommand

# Sensitive data leaks
agent-browser network har stop auth-dump.har   # HAR files contain auth tokens — gitignore!
git add *.har                                  # NEVER commit HAR captures

Related Skills

  • agent-browser (upstream) — Full command reference and usage patterns
  • portless (upstream) — Stable named .localhost URLs for local dev servers
  • ork:web-research-workflow — Unified decision tree for web research
  • ork:testing-e2e — E2E testing patterns including Playwright and webapp testing
  • ork:api-design — API design patterns for endpoints discovered during scraping
Weekly Installs
114
GitHub Stars
150
First Seen
Feb 13, 2026
Installed on
opencode108
gemini-cli107
codex106
cursor106
github-copilot106
amp103