You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
412 lines
33 KiB
412 lines
33 KiB
{
|
|
"links": [
|
|
{
|
|
"text": "ClawHub",
|
|
"href": "https://clawhub.ai/"
|
|
},
|
|
{
|
|
"text": "Skills",
|
|
"href": "https://clawhub.ai/skills"
|
|
},
|
|
{
|
|
"text": "Upload",
|
|
"href": "https://clawhub.ai/upload"
|
|
},
|
|
{
|
|
"text": "Import",
|
|
"href": "https://clawhub.ai/import"
|
|
},
|
|
{
|
|
"text": "Search",
|
|
"href": "https://clawhub.ai/skills?focus=search"
|
|
},
|
|
{
|
|
"text": "@TheSethRose",
|
|
"href": "https://clawhub.ai/u/TheSethRose"
|
|
},
|
|
{
|
|
"text": "View report →",
|
|
"href": "https://www.virustotal.com/gui/file/29701aa09cb5e5e4ee1bed1fc35e1307b6a944cf35420b4e2c991abe1178bb53"
|
|
},
|
|
{
|
|
"text": "Download zip",
|
|
"href": "https://wry-manatee-359.convex.site/api/v1/download?slug=agent-browser"
|
|
},
|
|
{
|
|
"text": "https://github.com/TheSethRose/Agent-Browser-CLI",
|
|
"href": "https://github.com/TheSethRose/Agent-Browser-CLI"
|
|
},
|
|
{
|
|
"text": "https://github.com/vercel-labs/agent-browser",
|
|
"href": "https://github.com/vercel-labs/agent-browser"
|
|
},
|
|
{
|
|
"text": "OpenClaw",
|
|
"href": "https://openclaw.ai/"
|
|
},
|
|
{
|
|
"text": "Vercel",
|
|
"href": "https://vercel.com/"
|
|
},
|
|
{
|
|
"text": "Convex",
|
|
"href": "https://www.convex.dev/"
|
|
},
|
|
{
|
|
"text": "Open source (MIT)",
|
|
"href": "https://github.com/openclaw/clawhub"
|
|
},
|
|
{
|
|
"text": "Peter Steinberger",
|
|
"href": "https://steipete.me/"
|
|
}
|
|
],
|
|
"buttons": [
|
|
{
|
|
"text": "",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "System",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "Light",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "Dark",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "Sign inwith GitHub",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "The skill is an instruction-only wrapper for an agent-browser CLI and its declared requirements (node/npm and an npm-installable CLI) match the documented behavior — nothing in the skill files requests unrelated credentials or system access.Details ▾",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "Files",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "Compare",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "Versions",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "CONTRIBUTING.md1.6 KB",
|
|
"onclick": null
|
|
},
|
|
{
|
|
"text": "SKILL.md10.0 KB",
|
|
"onclick": null
|
|
}
|
|
],
|
|
"codeElements": [
|
|
{
|
|
"text": "npm install -g agent-browser\nagent-browser install\nagent-browser install --with-deps",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "npm install -g agent-browser\nagent-browser install\nagent-browser install --with-deps",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "git clone https://github.com/vercel-labs/agent-browser\ncd agent-browser\npnpm install\npnpm build\nagent-browser install",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "git clone https://github.com/vercel-labs/agent-browser\ncd agent-browser\npnpm install\npnpm build\nagent-browser install",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser open <url> # Navigate to page\nagent-browser snapshot -i # Get interactive elements with refs\nagent-browser click @e1 # Click element by ref\nagent-browser fill @e2 \"text\" # Fill input by ref\nagent-browser close # Close browser",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser open <url> # Navigate to page\nagent-browser snapshot -i # Get interactive elements with refs\nagent-browser click @e1 # Click element by ref\nagent-browser fill @e2 \"text\" # Fill input by ref\nagent-browser close # Close browser",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser open <url>",
|
|
"className": "",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser snapshot -i",
|
|
"className": "",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "@e1",
|
|
"className": "",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "@e2",
|
|
"className": "",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser open <url> # Navigate to URL\nagent-browser back # Go back\nagent-browser forward # Go forward\nagent-browser reload # Reload page\nagent-browser close # Close browser",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser open <url> # Navigate to URL\nagent-browser back # Go back\nagent-browser forward # Go forward\nagent-browser reload # Reload page\nagent-browser close # Close browser",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser snapshot # Full accessibility tree\nagent-browser snapshot -i # Interactive elements only (recommended)\nagent-browser snapshot -c # Compact output\nagent-browser snapshot -d 3 # Limit depth to 3\nagent-browser snapshot -s \"#main\" # Scope to CSS selector",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser snapshot # Full accessibility tree\nagent-browser snapshot -i # Interactive elements only (recommended)\nagent-browser snapshot -c # Compact output\nagent-browser snapshot -d 3 # Limit depth to 3\nagent-browser snapshot -s \"#main\" # Scope to CSS selector",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser click @e1 # Click\nagent-browser dblclick @e1 # Double-click\nagent-browser focus @e1 # Focus element\nagent-browser fill @e2 \"text\" # Clear and type\nagent-browser type @e2 \"text\" # Type without clearing\nagent-browser press Enter # Press key\nagent-browser press Control+a # Key combination\nagent-browser keydown Shift # Hold key down\nagent-browser keyup Shift # Release key\nagent-browser hover @e1 # Hover\nagent-browser check @e1 # Check checkbox\nagent-browser uncheck @e1 # Uncheck checkbox\nagent-browser select @e1 \"value\" # Select dropdown\nagent-browser scroll down 500 # Scroll page\nagent-browser scrollintoview @e1 # Scroll element into view\nagent-browser drag @e1 @e2 # Drag and drop\nagent-browser upload @e1 file.pdf # Upload files",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser click @e1 # Click\nagent-browser dblclick @e1 # Double-click\nagent-browser focus @e1 # Focus element\nagent-browser fill @e2 \"text\" # Clear and type\nagent-browser type @e2 \"text\" # Type without clearing\nagent-browser press Enter # Press key\nagent-browser press Control+a # Key combination\nagent-browser keydown Shift # Hold key down\nagent-browser keyup Shift # Release key\nagent-browser hover @e1 # Hover\nagent-browser check @e1 # Check checkbox\nagent-browser uncheck @e1 # Uncheck checkbox\nagent-browser select @e1 \"value\" # Select dropdown\nagent-browser scroll down 500 # Scroll page\nagent-browser scrollintoview @e1 # Scroll element into view\nagent-browser drag @e1 @e2 # Drag and drop\nagent-browser upload @e1 file.pdf # Upload files",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser get text @e1 # Get element text\nagent-browser get html @e1 # Get innerHTML\nagent-browser get value @e1 # Get input value\nagent-browser get attr @e1 href # Get attribute\nagent-browser get title # Get page title\nagent-browser get url # Get current URL\nagent-browser get count \".item\" # Count matching elements\nagent-browser get box @e1 # Get bounding box",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser get text @e1 # Get element text\nagent-browser get html @e1 # Get innerHTML\nagent-browser get value @e1 # Get input value\nagent-browser get attr @e1 href # Get attribute\nagent-browser get title # Get page title\nagent-browser get url # Get current URL\nagent-browser get count \".item\" # Count matching elements\nagent-browser get box @e1 # Get bounding box",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser is visible @e1 # Check if visible\nagent-browser is enabled @e1 # Check if enabled\nagent-browser is checked @e1 # Check if checked",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser is visible @e1 # Check if visible\nagent-browser is enabled @e1 # Check if enabled\nagent-browser is checked @e1 # Check if checked",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser screenshot # Screenshot to stdout\nagent-browser screenshot path.png # Save to file\nagent-browser screenshot --full # Full page\nagent-browser pdf output.pdf # Save as PDF",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser screenshot # Screenshot to stdout\nagent-browser screenshot path.png # Save to file\nagent-browser screenshot --full # Full page\nagent-browser pdf output.pdf # Save as PDF",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser record start ./demo.webm # Start recording (uses current URL + state)\nagent-browser click @e1 # Perform actions\nagent-browser record stop # Stop and save video\nagent-browser record restart ./take2.webm # Stop current + start new recording",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser record start ./demo.webm # Start recording (uses current URL + state)\nagent-browser click @e1 # Perform actions\nagent-browser record stop # Stop and save video\nagent-browser record restart ./take2.webm # Stop current + start new recording",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser wait @e1 # Wait for element\nagent-browser wait 2000 # Wait milliseconds\nagent-browser wait --text \"Success\" # Wait for text\nagent-browser wait --url \"/dashboard\" # Wait for URL pattern\nagent-browser wait --load networkidle # Wait for network idle\nagent-browser wait --fn \"window.ready\" # Wait for JS condition",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser wait @e1 # Wait for element\nagent-browser wait 2000 # Wait milliseconds\nagent-browser wait --text \"Success\" # Wait for text\nagent-browser wait --url \"/dashboard\" # Wait for URL pattern\nagent-browser wait --load networkidle # Wait for network idle\nagent-browser wait --fn \"window.ready\" # Wait for JS condition",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser mouse move 100 200 # Move mouse\nagent-browser mouse down left # Press button\nagent-browser mouse up left # Release button\nagent-browser mouse wheel 100 # Scroll wheel",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser mouse move 100 200 # Move mouse\nagent-browser mouse down left # Press button\nagent-browser mouse up left # Release button\nagent-browser mouse wheel 100 # Scroll wheel",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser find role button click --name \"Submit\"\nagent-browser find text \"Sign In\" click\nagent-browser find label \"Email\" fill \"user@test.com\"\nagent-browser find first \".item\" click\nagent-browser find nth 2 \"a\" text",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser find role button click --name \"Submit\"\nagent-browser find text \"Sign In\" click\nagent-browser find label \"Email\" fill \"user@test.com\"\nagent-browser find first \".item\" click\nagent-browser find nth 2 \"a\" text",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser set viewport 1920 1080 # Set viewport size\nagent-browser set device \"iPhone 14\" # Emulate device\nagent-browser set geo 37.7749 -122.4194 # Set geolocation\nagent-browser set offline on # Toggle offline mode\nagent-browser set headers '{\"X-Key\":\"v\"}' # Extra HTTP headers\nagent-browser set credentials user pass # HTTP basic auth\nagent-browser set media dark # Emulate color scheme",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser set viewport 1920 1080 # Set viewport size\nagent-browser set device \"iPhone 14\" # Emulate device\nagent-browser set geo 37.7749 -122.4194 # Set geolocation\nagent-browser set offline on # Toggle offline mode\nagent-browser set headers '{\"X-Key\":\"v\"}' # Extra HTTP headers\nagent-browser set credentials user pass # HTTP basic auth\nagent-browser set media dark # Emulate color scheme",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser cookies # Get all cookies\nagent-browser cookies set name value # Set cookie\nagent-browser cookies clear # Clear cookies\nagent-browser storage local # Get all localStorage\nagent-browser storage local key # Get specific key\nagent-browser storage local set k v # Set value\nagent-browser storage local clear # Clear all",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser cookies # Get all cookies\nagent-browser cookies set name value # Set cookie\nagent-browser cookies clear # Clear cookies\nagent-browser storage local # Get all localStorage\nagent-browser storage local key # Get specific key\nagent-browser storage local set k v # Set value\nagent-browser storage local clear # Clear all",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser network route <url> # Intercept requests\nagent-browser network route <url> --abort # Block requests\nagent-browser network route <url> --body '{}' # Mock response\nagent-browser network unroute [url] # Remove routes\nagent-browser network requests # View tracked requests\nagent-browser network requests --filter api # Filter requests",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser network route <url> # Intercept requests\nagent-browser network route <url> --abort # Block requests\nagent-browser network route <url> --body '{}' # Mock response\nagent-browser network unroute [url] # Remove routes\nagent-browser network requests # View tracked requests\nagent-browser network requests --filter api # Filter requests",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser tab # List tabs\nagent-browser tab new [url] # New tab\nagent-browser tab 2 # Switch to tab\nagent-browser tab close # Close tab\nagent-browser window new # New window",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser tab # List tabs\nagent-browser tab new [url] # New tab\nagent-browser tab 2 # Switch to tab\nagent-browser tab close # Close tab\nagent-browser window new # New window",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser frame \"#iframe\" # Switch to iframe\nagent-browser frame main # Back to main frame",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser frame \"#iframe\" # Switch to iframe\nagent-browser frame main # Back to main frame",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser dialog accept [text] # Accept dialog\nagent-browser dialog dismiss # Dismiss dialog",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser dialog accept [text] # Accept dialog\nagent-browser dialog dismiss # Dismiss dialog",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser eval \"document.title\" # Run JavaScript",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser eval \"document.title\" # Run JavaScript",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser state save auth.json # Save session state\nagent-browser state load auth.json # Load saved state",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser state save auth.json # Save session state\nagent-browser state load auth.json # Load saved state",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser open https://example.com/form\nagent-browser snapshot -i\n# Output shows: textbox \"Email\" [ref=e1], textbox \"Password\" [ref=e2], button \"Submit\" [ref=e3]\n\nagent-browser fill @e1 \"user@example.com\"\nagent-browser fill @e2 \"password123\"\nagent-browser click @e3\nagent-browser wait --load networkidle\nagent-browser snapshot -i # Check result",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser open https://example.com/form\nagent-browser snapshot -i\n# Output shows: textbox \"Email\" [ref=e1], textbox \"Password\" [ref=e2], button \"Submit\" [ref=e3]\n\nagent-browser fill @e1 \"user@example.com\"\nagent-browser fill @e2 \"password123\"\nagent-browser click @e3\nagent-browser wait --load networkidle\nagent-browser snapshot -i # Check result",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "# Login once\nagent-browser open https://app.example.com/login\nagent-browser snapshot -i\nagent-browser fill @e1 \"username\"\nagent-browser fill @e2 \"password\"\nagent-browser click @e3\nagent-browser wait --url \"/dashboard\"\nagent-browser state save auth.json\n\n# Later sessions: load saved state\nagent-browser state load auth.json\nagent-browser open https://app.example.com/dashboard",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "# Login once\nagent-browser open https://app.example.com/login\nagent-browser snapshot -i\nagent-browser fill @e1 \"username\"\nagent-browser fill @e2 \"password\"\nagent-browser click @e3\nagent-browser wait --url \"/dashboard\"\nagent-browser state save auth.json\n\n# Later sessions: load saved state\nagent-browser state load auth.json\nagent-browser open https://app.example.com/dashboard",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser --session test1 open site-a.com\nagent-browser --session test2 open site-b.com\nagent-browser session list",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser --session test1 open site-a.com\nagent-browser --session test2 open site-b.com\nagent-browser session list",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "--json",
|
|
"className": "",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser snapshot -i --json\nagent-browser get text @e1 --json",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser snapshot -i --json\nagent-browser get text @e1 --json",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
},
|
|
{
|
|
"text": "agent-browser open example.com --headed # Show browser window\nagent-browser console # View console messages\nagent-browser console --clear # Clear console\nagent-browser errors # View page errors\nagent-browser errors --clear # Clear errors\nagent-browser highlight @e1 # Highlight element\nagent-browser trace start # Start recording trace\nagent-browser trace stop trace.zip # Stop and save trace\nagent-browser record start ./debug.webm # Record from current page\nagent-browser record stop # Save recording\nagent-browser --cdp 9222 snapshot # Connect via CDP",
|
|
"className": "",
|
|
"tagName": "PRE"
|
|
},
|
|
{
|
|
"text": "agent-browser open example.com --headed # Show browser window\nagent-browser console # View console messages\nagent-browser console --clear # Clear console\nagent-browser errors # View page errors\nagent-browser errors --clear # Clear errors\nagent-browser highlight @e1 # Highlight element\nagent-browser trace start # Start recording trace\nagent-browser trace stop trace.zip # Stop and save trace\nagent-browser record start ./debug.webm # Record from current page\nagent-browser record stop # Save recording\nagent-browser --cdp 9222 snapshot # Connect via CDP",
|
|
"className": "language-bash",
|
|
"tagName": "CODE"
|
|
}
|
|
],
|
|
"allText": "ClawHub\nSkills\nUpload\nImport\nSearch\nSystem\nLight\nDark\nSign in\nwith GitHub\nSkill flagged — suspicious patterns detected\n\nClawHub Security flagged this skill as suspicious. Review the scan results before using.\n\nAgent Browser\n\nA fast Rust-based headless browser automation CLI with Node.js fallback that enables AI agents to navigate, click, type, and snapshot pages via structured commands.\n\n⭐ 369 ·\n70.5k · 928 current installs · 957 all-time installs\nby\nSeth Rose\n·\n@TheSethRose\nSECURITY SCAN\nVirusTotal\nSuspicious\nView report →\nOpenClaw\nBenign\nHIGH CONFIDENCE\nThe skill is an instruction-only wrapper for an agent-browser CLI and its declared requirements (node/npm and an npm-installable CLI) match the documented behavior — nothing in the skill files requests unrelated credentials or system access.\nDetails\n▾\n\nLike a lobster shell, security has layers — review code before you run it.\n\nCURRENT VERSION\nv0.2.0\nDownload zip\nautomation\nv0.1.0\nbrowser\nv0.1.0\nheadless\nv0.1.0\nlatest\nv0.2.0\nweb\nv0.1.0\nRuntime requirements\n🌐 Clawdis\nBins\nnode, npm\nFiles\nCompare\nVersions\nSKILL.md\nBrowser Automation with agent-browser\nInstallation\nnpm recommended\nnpm install -g agent-browser\nagent-browser install\nagent-browser install --with-deps\n\nFrom Source\ngit clone https://github.com/vercel-labs/agent-browser\ncd agent-browser\npnpm install\npnpm build\nagent-browser install\n\nQuick start\nagent-browser open <url> # Navigate to page\nagent-browser snapshot -i # Get interactive elements with refs\nagent-browser click @e1 # Click element by ref\nagent-browser fill @e2 \"text\" # Fill input by ref\nagent-browser close # Close browser\n\nCore workflow\nNavigate: agent-browser open <url>\nSnapshot: agent-browser snapshot -i (returns elements with refs like @e1, @e2)\nInteract using refs from the snapshot\nRe-snapshot after navigation or significant DOM changes\nCommands\nNavigation\nagent-browser open <url> # Navigate to URL\nagent-browser back # Go back\nagent-browser forward # Go forward\nagent-browser reload # Reload page\nagent-browser close # Close browser\n\nSnapshot (page analysis)\nagent-browser snapshot # Full accessibility tree\nagent-browser snapshot -i # Interactive elements only (recommended)\nagent-browser snapshot -c # Compact output\nagent-browser snapshot -d 3 # Limit depth to 3\nagent-browser snapshot -s \"#main\" # Scope to CSS selector\n\nInteractions (use @refs from snapshot)\nagent-browser click @e1 # Click\nagent-browser dblclick @e1 # Double-click\nagent-browser focus @e1 # Focus element\nagent-browser fill @e2 \"text\" # Clear and type\nagent-browser type @e2 \"text\" # Type without clearing\nagent-browser press Enter # Press key\nagent-browser press Control+a # Key combination\nagent-browser keydown Shift # Hold key down\nagent-browser keyup Shift # Release key\nagent-browser hover @e1 # Hover\nagent-browser check @e1 # Check checkbox\nagent-browser uncheck @e1 # Uncheck checkbox\nagent-browser select @e1 \"value\" # Select dropdown\nagent-browser scroll down 500 # Scroll page\nagent-browser scrollintoview @e1 # Scroll element into view\nagent-browser drag @e1 @e2 # Drag and drop\nagent-browser upload @e1 file.pdf # Upload files\n\nGet information\nagent-browser get text @e1 # Get element text\nagent-browser get html @e1 # Get innerHTML\nagent-browser get value @e1 # Get input value\nagent-browser get attr @e1 href # Get attribute\nagent-browser get title # Get page title\nagent-browser get url # Get current URL\nagent-browser get count \".item\" # Count matching elements\nagent-browser get box @e1 # Get bounding box\n\nCheck state\nagent-browser is visible @e1 # Check if visible\nagent-browser is enabled @e1 # Check if enabled\nagent-browser is checked @e1 # Check if checked\n\nScreenshots & PDF\nagent-browser screenshot # Screenshot to stdout\nagent-browser screenshot path.png # Save to file\nagent-browser screenshot --full # Full page\nagent-browser pdf output.pdf # Save as PDF\n\nVideo recording\nagent-browser record start ./demo.webm # Start recording (uses current URL + state)\nagent-browser click @e1 # Perform actions\nagent-browser record stop # Stop and save video\nagent-browser record restart ./take2.webm # Stop current + start new recording\n\n\nRecording creates a fresh context but preserves cookies/storage from your session. If no URL is provided, it automatically returns to your current page. For smooth demos, explore first, then start recording.\n\nWait\nagent-browser wait @e1 # Wait for element\nagent-browser wait 2000 # Wait milliseconds\nagent-browser wait --text \"Success\" # Wait for text\nagent-browser wait --url \"/dashboard\" # Wait for URL pattern\nagent-browser wait --load networkidle # Wait for network idle\nagent-browser wait --fn \"window.ready\" # Wait for JS condition\n\nMouse control\nagent-browser mouse move 100 200 # Move mouse\nagent-browser mouse down left # Press button\nagent-browser mouse up left # Release button\nagent-browser mouse wheel 100 # Scroll wheel\n\nSemantic locators (alternative to refs)\nagent-browser find role button click --name \"Submit\"\nagent-browser find text \"Sign In\" click\nagent-browser find label \"Email\" fill \"user@test.com\"\nagent-browser find first \".item\" click\nagent-browser find nth 2 \"a\" text\n\nBrowser settings\nagent-browser set viewport 1920 1080 # Set viewport size\nagent-browser set device \"iPhone 14\" # Emulate device\nagent-browser set geo 37.7749 -122.4194 # Set geolocation\nagent-browser set offline on # Toggle offline mode\nagent-browser set headers '{\"X-Key\":\"v\"}' # Extra HTTP headers\nagent-browser set credentials user pass # HTTP basic auth\nagent-browser set media dark # Emulate color scheme\n\nCookies & Storage\nagent-browser cookies # Get all cookies\nagent-browser cookies set name value # Set cookie\nagent-browser cookies clear # Clear cookies\nagent-browser storage local # Get all localStorage\nagent-browser storage local key # Get specific key\nagent-browser storage local set k v # Set value\nagent-browser storage local clear # Clear all\n\nNetwork\nagent-browser network route <url> # Intercept requests\nagent-browser network route <url> --abort # Block requests\nagent-browser network route <url> --body '{}' # Mock response\nagent-browser network unroute [url] # Remove routes\nagent-browser network requests # View tracked requests\nagent-browser network requests --filter api # Filter requests\n\nTabs & Windows\nagent-browser tab # List tabs\nagent-browser tab new [url] # New tab\nagent-browser tab 2 # Switch to tab\nagent-browser tab close # Close tab\nagent-browser window new # New window\n\nFrames\nagent-browser frame \"#iframe\" # Switch to iframe\nagent-browser frame main # Back to main frame\n\nDialogs\nagent-browser dialog accept [text] # Accept dialog\nagent-browser dialog dismiss # Dismiss dialog\n\nJavaScript\nagent-browser eval \"document.title\" # Run JavaScript\n\nState management\nagent-browser state save auth.json # Save session state\nagent-browser state load auth.json # Load saved state\n\nExample: Form submission\nagent-browser open https://example.com/form\nagent-browser snapshot -i\n# Output shows: textbox \"Email\" [ref=e1], textbox \"Password\" [ref=e2], button \"Submit\" [ref=e3]\n\nagent-browser fill @e1 \"user@example.com\"\nagent-browser fill @e2 \"password123\"\nagent-browser click @e3\nagent-browser wait --load networkidle\nagent-browser snapshot -i # Check result\n\nExample: Authentication with saved state\n# Login once\nagent-browser open https://app.example.com/login\nagent-browser snapshot -i\nagent-browser fill @e1 \"username\"\nagent-browser fill @e2 \"password\"\nagent-browser click @e3\nagent-browser wait --url \"/dashboard\"\nagent-browser state save auth.json\n\n# Later sessions: load saved state\nagent-browser state load auth.json\nagent-browser open https://app.example.com/dashboard\n\nSessions (parallel browsers)\nagent-browser --session test1 open site-a.com\nagent-browser --session test2 open site-b.com\nagent-browser session list\n\nJSON output (for parsing)\n\nAdd --json for machine-readable output:\n\nagent-browser snapshot -i --json\nagent-browser get text @e1 --json\n\nDebugging\nagent-browser open example.com --headed # Show browser window\nagent-browser console # View console messages\nagent-browser console --clear # Clear console\nagent-browser errors # View page errors\nagent-browser errors --clear # Clear errors\nagent-browser highlight @e1 # Highlight element\nagent-browser trace start # Start recording trace\nagent-browser trace stop trace.zip # Stop and save trace\nagent-browser record start ./debug.webm # Record from current page\nagent-browser record stop # Save recording\nagent-browser --cdp 9222 snapshot # Connect via CDP\n\nTroubleshooting\nIf the command is not found on Linux ARM64, use the full path in the bin folder.\nIf an element is not found, use snapshot to find the correct ref.\nIf the page is not loaded, add a wait command after navigation.\nUse --headed to see the browser window for debugging.\nOptions\n--session <name> uses an isolated session.\n--json provides JSON output.\n--full takes a full page screenshot.\n--headed shows the browser window.\n--timeout sets the command timeout in milliseconds.\n--cdp <port> connects via Chrome DevTools Protocol.\nNotes\nRefs are stable per page load but change on navigation.\nAlways snapshot after navigation to get new refs.\nUse fill instead of type for input fields to ensure existing text is cleared.\nReporting Issues\nSkill issues: Open an issue at https://github.com/TheSethRose/Agent-Browser-CLI\nagent-browser CLI issues: Open an issue at https://github.com/vercel-labs/agent-browser\nFiles\n2 total\nCONTRIBUTING.md\n1.6 KB\nSKILL.md\n10.0 KB\nSelect a file\nSelect a file to preview.\nComments\n\nSign in to comment.\n\n@bardusco\nScreenshots of web pages → ClawShot feed. Agents could share what they're browsing. Interesting possibilities here.\n\nclawshot.ai 🦞\nClawHub · An OpenClaw project · Deployed on Vercel · Powered by Convex · Open source (MIT) · Peter Steinberger.",
|
|
"scripts": [
|
|
{
|
|
"src": "https://clawhub.ai/_vercel/insights/script.js",
|
|
"content": ""
|
|
},
|
|
{
|
|
"src": "",
|
|
"content": ""
|
|
},
|
|
{
|
|
"src": "",
|
|
"content": ""
|
|
}
|
|
]
|
|
}
|