# Scrapfly Documentation

## Table of Contents

### Dashboard

- [Intro](https://scrapfly.io/docs)
- [Project](https://scrapfly.io/docs/project)
- [Account](https://scrapfly.io/docs/account)
- [Workspace & Team](https://scrapfly.io/docs/workspace-and-team)
- [Billing](https://scrapfly.io/docs/billing)

### Products

#### MCP Server

- [Getting Started](https://scrapfly.io/docs/mcp/getting-started)
- [Tools & API Spec](https://scrapfly.io/docs/mcp/tools)
- [Authentication](https://scrapfly.io/docs/mcp/authentication)
- [Examples & Use Cases](https://scrapfly.io/docs/mcp/examples)
- [FAQ](https://scrapfly.io/docs/mcp/faq)
##### Integrations

- [Overview](https://scrapfly.io/docs/mcp/integrations)
- [Claude Desktop](https://scrapfly.io/docs/mcp/integrations/claude-desktop)
- [Claude Code](https://scrapfly.io/docs/mcp/integrations/claude-code)
- [ChatGPT](https://scrapfly.io/docs/mcp/integrations/chatgpt)
- [Cursor](https://scrapfly.io/docs/mcp/integrations/cursor)
- [Cline](https://scrapfly.io/docs/mcp/integrations/cline)
- [Windsurf](https://scrapfly.io/docs/mcp/integrations/windsurf)
- [Zed](https://scrapfly.io/docs/mcp/integrations/zed)
- [Roo Code](https://scrapfly.io/docs/mcp/integrations/roo-code)
- [VS Code](https://scrapfly.io/docs/mcp/integrations/vscode)
- [LangChain](https://scrapfly.io/docs/mcp/integrations/langchain)
- [LlamaIndex](https://scrapfly.io/docs/mcp/integrations/llamaindex)
- [CrewAI](https://scrapfly.io/docs/mcp/integrations/crewai)
- [OpenAI](https://scrapfly.io/docs/mcp/integrations/openai)
- [n8n](https://scrapfly.io/docs/mcp/integrations/n8n)
- [Make](https://scrapfly.io/docs/mcp/integrations/make)
- [Zapier](https://scrapfly.io/docs/mcp/integrations/zapier)
- [Vapi AI](https://scrapfly.io/docs/mcp/integrations/vapi)
- [Agent Builder](https://scrapfly.io/docs/mcp/integrations/agent-builder)
- [Custom Client](https://scrapfly.io/docs/mcp/integrations/custom-client)


#### Web Scraping API

- [Getting Started](https://scrapfly.io/docs/scrape-api/getting-started)
- [API Specification]()
- [Monitoring](https://scrapfly.io/docs/monitoring)
- [Customize Request](https://scrapfly.io/docs/scrape-api/custom)
- [Debug](https://scrapfly.io/docs/scrape-api/debug)
- [Anti Scraping Protection](https://scrapfly.io/docs/scrape-api/anti-scraping-protection)
- [Proxy](https://scrapfly.io/docs/scrape-api/proxy)
- [Proxy Mode](https://scrapfly.io/docs/scrape-api/proxy-mode)
- [Proxy Mode - Screaming Frog](https://scrapfly.io/docs/scrape-api/proxy-mode/screaming-frog)
- [Proxy Mode - Apify](https://scrapfly.io/docs/scrape-api/proxy-mode/apify)
- [(Auto) Data Extraction](https://scrapfly.io/docs/scrape-api/extraction)
- [Javascript Rendering](https://scrapfly.io/docs/scrape-api/javascript-rendering)
- [Javascript Scenario](https://scrapfly.io/docs/scrape-api/javascript-scenario)
- [SSL](https://scrapfly.io/docs/scrape-api/ssl)
- [DNS](https://scrapfly.io/docs/scrape-api/dns)
- [Cache](https://scrapfly.io/docs/scrape-api/cache)
- [Session](https://scrapfly.io/docs/scrape-api/session)
- [Webhook](https://scrapfly.io/docs/scrape-api/webhook)
- [Screenshot](https://scrapfly.io/docs/scrape-api/screenshot)
- [Errors](https://scrapfly.io/docs/scrape-api/errors)
- [Timeout](https://scrapfly.io/docs/scrape-api/understand-timeout)
- [Throttling](https://scrapfly.io/docs/throttling)
- [Troubleshoot](https://scrapfly.io/docs/scrape-api/troubleshoot)
- [Billing](https://scrapfly.io/docs/scrape-api/billing)
- [FAQ](https://scrapfly.io/docs/scrape-api/faq)

#### Crawler API

- [Getting Started](https://scrapfly.io/docs/crawler-api/getting-started)
- [API Specification]()
- [Retrieving Results](https://scrapfly.io/docs/crawler-api/results)
- [WARC Format](https://scrapfly.io/docs/crawler-api/warc-format)
- [Data Extraction](https://scrapfly.io/docs/crawler-api/extraction-rules)
- [Webhook](https://scrapfly.io/docs/crawler-api/webhook)
- [Billing](https://scrapfly.io/docs/crawler-api/billing)
- [Errors](https://scrapfly.io/docs/crawler-api/errors)
- [Troubleshoot](https://scrapfly.io/docs/crawler-api/troubleshoot)
- [FAQ](https://scrapfly.io/docs/crawler-api/faq)

#### Screenshot API

- [Getting Started](https://scrapfly.io/docs/screenshot-api/getting-started)
- [API Specification]()
- [Accessibility Testing](https://scrapfly.io/docs/screenshot-api/accessibility)
- [Webhook](https://scrapfly.io/docs/screenshot-api/webhook)
- [Billing](https://scrapfly.io/docs/screenshot-api/billing)
- [Errors](https://scrapfly.io/docs/screenshot-api/errors)

#### Extraction API

- [Getting Started](https://scrapfly.io/docs/extraction-api/getting-started)
- [API Specification]()
- [Rules Template](https://scrapfly.io/docs/extraction-api/rules-and-template)
- [LLM Extraction](https://scrapfly.io/docs/extraction-api/llm-prompt)
- [AI Auto Extraction](https://scrapfly.io/docs/extraction-api/automatic-ai)
- [Webhook](https://scrapfly.io/docs/extraction-api/webhook)
- [Billing](https://scrapfly.io/docs/extraction-api/billing)
- [Errors](https://scrapfly.io/docs/extraction-api/errors)
- [FAQ](https://scrapfly.io/docs/extraction-api/faq)

#### Proxy Saver

- [Getting Started](https://scrapfly.io/docs/proxy-saver/getting-started)
- [Fingerprints](https://scrapfly.io/docs/proxy-saver/fingerprints)
- [Optimizations](https://scrapfly.io/docs/proxy-saver/optimizations)
- [SSL Certificates](https://scrapfly.io/docs/proxy-saver/certificates)
- [Protocols](https://scrapfly.io/docs/proxy-saver/protocols)
- [Pacfile](https://scrapfly.io/docs/proxy-saver/pacfile)
- [Secure Credentials](https://scrapfly.io/docs/proxy-saver/security)
- [Billing](https://scrapfly.io/docs/proxy-saver/billing)

#### Cloud Browser API

- [Getting Started](https://scrapfly.io/docs/cloud-browser-api/getting-started)
- [Proxy & Geo-Targeting](https://scrapfly.io/docs/cloud-browser-api/proxy)
- [Unblock API](https://scrapfly.io/docs/cloud-browser-api/unblock)
- [File Downloads](https://scrapfly.io/docs/cloud-browser-api/file-downloads)
- [Session Resume](https://scrapfly.io/docs/cloud-browser-api/session-resume)
- [Human-in-the-Loop](https://scrapfly.io/docs/cloud-browser-api/human-in-the-loop)
- [Debug Mode](https://scrapfly.io/docs/cloud-browser-api/debug-mode)
- [Bring Your Own Proxy](https://scrapfly.io/docs/cloud-browser-api/bring-your-own-proxy)
- [Browser Extensions](https://scrapfly.io/docs/cloud-browser-api/extensions)
- [Native Browser MCP](https://scrapfly.io/docs/cloud-browser-api/mcp)
- [DevTools Protocol](https://scrapfly.io/docs/cloud-browser-api/cdp-reference)
##### Integrations

- [Puppeteer](https://scrapfly.io/docs/cloud-browser-api/puppeteer)
- [Playwright](https://scrapfly.io/docs/cloud-browser-api/playwright)
- [Selenium](https://scrapfly.io/docs/cloud-browser-api/selenium)
- [Vercel Agent Browser](https://scrapfly.io/docs/cloud-browser-api/agent-browser)
- [Browser Use](https://scrapfly.io/docs/cloud-browser-api/browser-use)
- [Stagehand](https://scrapfly.io/docs/cloud-browser-api/stagehand)

- [Billing](https://scrapfly.io/docs/cloud-browser-api/billing)
- [Errors](https://scrapfly.io/docs/cloud-browser-api/errors)


### Tools

- [Antibot Detector](https://scrapfly.io/docs/tools/antibot-detector)

### SDK

- [Golang](https://scrapfly.io/docs/sdk/golang)
- [Python](https://scrapfly.io/docs/sdk/python)
- [Rust](https://scrapfly.io/docs/sdk/rust)
- [TypeScript](https://scrapfly.io/docs/sdk/typescript)
- [Scrapy](https://scrapfly.io/docs/sdk/scrapy)

### Integrations

- [Getting Started](https://scrapfly.io/docs/integration/getting-started)
- [LangChain](https://scrapfly.io/docs/integration/langchain)
- [LlamaIndex](https://scrapfly.io/docs/integration/llamaindex)
- [CrewAI](https://scrapfly.io/docs/integration/crewai)
- [Zapier](https://scrapfly.io/docs/integration/zapier)
- [Make](https://scrapfly.io/docs/integration/make)
- [n8n](https://scrapfly.io/docs/integration/n8n)

### Academy

- [Overview](https://scrapfly.io/academy)
- [Web Scraping Overview](https://scrapfly.io/academy/scraping-overview)
- [Tools](https://scrapfly.io/academy/tools-overview)
- [Reverse Engineering](https://scrapfly.io/academy/reverse-engineering)
- [Static Scraping](https://scrapfly.io/academy/static-scraping)
- [HTML Parsing](https://scrapfly.io/academy/html-parsing)
- [Dynamic Scraping](https://scrapfly.io/academy/dynamic-scraping)
- [Hidden API Scraping](https://scrapfly.io/academy/hidden-api-scraping)
- [Headless Browsers](https://scrapfly.io/academy/headless-browsers)
- [Hidden Web Data](https://scrapfly.io/academy/hidden-web-data)
- [JSON Parsing](https://scrapfly.io/academy/json-parsing)
- [Data Processing](https://scrapfly.io/academy/data-processing)
- [Scaling](https://scrapfly.io/academy/scaling)
- [Walkthrough Summary](https://scrapfly.io/academy/walkthrough-summary)
- [Scraper Blocking](https://scrapfly.io/academy/scraper-blocking)
- [Proxies](https://scrapfly.io/academy/proxies)

---

 1. [DevTools Protocol](https://scrapfly.io/docs/cloud-browser-api/cdp-reference)
2. Antibot
 
  # Antibot

 Experimental Scrapfly 

**Dependencies:** [Accessibility](https://scrapfly.io/docs/cloud-browser-api/cdp-reference/Accessibility), [Page](https://scrapfly.io/docs/cloud-browser-api/cdp-reference/Page)

 - [Commands (21)](#commands)
- [Types (5)](#types)
 
   

No symbols match your filter.

## Commands

#### `Antibot.performAction`

 Scrapfly 

Performs an accessibility action on a node identified by AXNodeId.
Retries automatically (up to 10 times at 200ms intervals) for OOPIFs
where the browser-side AX tree may take time to populate.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `axNodeId` | `<a href="/docs/cloud-browser-api/cdp-reference/Accessibility#type-AXNodeId">Accessibility.AXNodeId</a>` |  |
| `action` | `string` | AX action to perform. Currently only "doDefault" is implemented. |
| `frameId`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Page#type-FrameId">Page.FrameId</a>` | Frame containing the target node. If omitted, uses the main frame. |
| `metadata`  (optional) | `string` |  |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.findAndPerformAction`

 Scrapfly 

Searches the browser-side AX tree across ALL frames (including OOPIFs)
for a node matching the selector, then performs the specified action.
Only "role" and "axNodeId" selector types are supported.
For "role" type, query is the AX role (e.g. "checkbox", "button")
and the browser walks all frames' AX trees. This works for OOPIF
frames where CDP Accessibility.getFullAXTree cannot reach
cross-process nodes.
Retries up to 40 times at 300ms intervals (~12s) if no match found.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` | Only "role" and "axNodeId" selector types are supported. |
| `action` | `string` | AX action to perform. Currently only "doDefault" is implemented. |
| `name`  (optional) | `string` | Optional AX accessible name substring to match. Filters matched nodes by their accessible name. Works with both role and axNodeId. |
| `frameUrl`  (optional) | `string` | Optional frame URL glob pattern to restrict search (e.g. "\*cloudflare.com\*"). |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |
| `foundNodeId`  (optional) | `string` | The AX node ID that was found and acted upon. |
| `foundRole`  (optional) | `string` | The role of the found node. |
| `foundName`  (optional) | `string` | The name of the found node. |

 

 

 

#### `Antibot.moveTo`

 Scrapfly 

Moves mouse to target with human-like Bezier curve trajectory.
Includes natural jitter and distortion to mimic hand tremor.
For non-steady moves greater than 50px, there is a 30% chance of
overshooting by 3-12px then correcting back.
Supports all selector types except bottom.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` | Position within element bounds as ratio \[0-1\] for each axis. Default: random position within 0.2-0.8 of bounds. |
| `absoluteOffset`  (optional) | `boolean` | For "coord" selector type only: if true, treat the query coordinates as an offset from the current mouse position rather than absolute viewport coordinates. Default: false. |
| `steady`  (optional) | `boolean` | If true, reduces curve deviation and distortion, and disables overshoot. Use for small or precise targets where accuracy matters. Default: false. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.clickOn`

 Scrapfly 

Moves to target then clicks with human-like timing.
Supports all selector types except bottom.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` |  |
| `button`  (optional) | `string` | Mouse button: "left", "right", or "middle". Default: "left". |
| `clickDuration`  (optional) | `number` | Hold duration in seconds between mousedown and mouseup. Default: random between 0.1 and 0.4 seconds. |
| `clickCount`  (optional) | `integer` | Number of clicks (e.g. 2 for double-click). Default: 1. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.dragAndDrop`

 Scrapfly 

Drag from source to destination with human-like Bezier movement.
Supports all selector types except bottom.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `from` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `to` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `fromRelativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` | Position within source element bounds as ratio \[0-1\]. Default: center area. |
| `toRelativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` | Position within destination element bounds as ratio \[0-1\]. Default: center area. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.clickAndHold`

 Scrapfly 

Moves to target element, presses mouse down, holds for a minimum time,
then releases. Used for captcha puzzles requiring long-press interactions.
Supports all selector types except bottom.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` |  |
| `holdTime`  (optional) | `number` | Minimum hold duration in seconds. Default: random between 1.0 and 3.0. |
| `button`  (optional) | `string` | Mouse button: "left", "right", or "middle". Default: "left". |
| `frameUrl`  (optional) | `string` | Frame URL glob pattern to restrict element search to matching frames. Uses shell-style wildcards (e.g. "\*cloudflare.com\*", "\*recaptcha\*"). |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.clickAndSlide`

 Scrapfly 

Moves to target element, presses mouse down, slides the mouse
to a target position, then releases.
Used for slider captcha puzzles.
Supports all selector types except bottom.

Two modes:
1\. Fixed distance: provide "distance" in CSS pixels.
2\. Target selector: provide "target" selector — the command resolves
 both source and target positions and computes the slide distance
 automatically with slight human-like imprecision.
At least one of "distance" or "target" must be provided.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` |  |
| `distance`  (optional) | `number` | Horizontal slide distance in CSS pixels (positive = right, negative = left). |
| `target`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` | Target element selector — the command slides from "selector" to "target". Distance is computed automatically with human-like imprecision. |
| `targetRelativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` | Position within target element bounds as ratio \[0-1\]. |
| `verticalOffset`  (optional) | `number` | Vertical slide offset in CSS pixels. Default: 0 (horizontal only). |
| `button`  (optional) | `string` | Mouse button: "left", "right", or "middle". Default: "left". |
| `frameUrl`  (optional) | `string` | Frame URL glob pattern to restrict element search to matching frames. Uses shell-style wildcards (e.g. "\*captcha\*"). |
| `overshoot`  (optional) | `boolean` | If true, overshoot past the destination on the X axis by 5-15px then correct back. Simulates a human dragging past the slider endpoint (captcha sites typically clamp the slider position). Default: false. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.scroll`

 Scrapfly 

Human-like scroll. Three modes:

1\. Element into view: provide selector (css/xpath/axNodeId/coord/role).
 Scrolls until element is within 20% of viewport center, using wheel
 events in 3-8 steps. Skips if already visible near center.

2\. Scroll to bottom: provide selector {type:"bottom", query:""}.
 Scrolls 0.5-0.9x viewport height per step, 3-8 wheel events with
 50-150ms delays. If mouse is near origin, first moves it to a random
 position with a Bezier curve. Returns atBottom=true when scrollY is
 within 5px of the maximum scroll offset.

3\. Manual delta: provide delta (no selector). Scrolls by the given pixel
 offset using 3-8 wheel steps.

Supports all selector types including bottom.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` | Target element to scroll into view, or {type:"bottom", query:""} to scroll toward page bottom. |
| `delta`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` | Manual scroll delta in CSS viewport pixels. x = horizontal, y = vertical. Negative y = scroll down, positive y = scroll up. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |
| `atBottom`  (optional) | `boolean` | True when the page is at or near the bottom (within 5px of max scroll). Only set when selector type is "bottom". |

 

 

 

#### `Antibot.typeText`

 Scrapfly 

Types text character by character with human WPM timing model.
Uses profile-aware keyboard mapping for correct key codes.
Timing: base\_delay = 60 / (wpm \* 5) seconds per keystroke, with
per-character random variation, common bigram speedup, space pauses,
and shift penalty for uppercase characters.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `text` | `string` |  |
| `wpm`  (optional) | `number` | Words per minute. Default: 60. Typical human range: 30-80. At 60 WPM: ~200ms base delay between keystrokes. At 30 WPM: ~400ms. At 120 WPM: ~100ms. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.fill`

 Scrapfly 

Clicks on element, optionally clears it, then types text with human timing.
Supports all selector types except bottom.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `text` | `string` |  |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` |  |
| `clear`  (optional) | `boolean` | Clear existing content first by sending Ctrl+A then Backspace. Default: false. |
| `wpm`  (optional) | `number` | Words per minute for typing. Default: 60. See typeText for timing details. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.showCursor`

 Scrapfly 

Injects a debug cursor overlay (red dot + trail) for visual testing.
Persists across navigations — re-injected automatically on page load.

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.getFrames`

 Scrapfly 

Returns all frames including OOPIFs with their metadata.
Uses ForEachRenderFrameHost to enumerate every frame in the page,
including cross-origin out-of-process iframes.

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `frames` | `array<<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-FrameInfo">FrameInfo</a>>` |  |

 

 

 

#### `Antibot.locateElement`

 Scrapfly 

Locates an element in a specific frame and returns its bounding box
in main-frame viewport coordinates (CSS pixels). This allows clicking
on elements inside OOPIFs with correct screen-space coordinates.
Only "css", "xpath", and "axNodeId" selector types are supported.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `frameId` | `<a href="/docs/cloud-browser-api/cdp-reference/Page#type-FrameId">Page.FrameId</a>` |  |
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` | Only css, xpath, and axNodeId selector types are supported. |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` |  |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |
| `pointX`  (optional) | `number` | Resolved click point in viewport coordinates. |
| `pointY`  (optional) | `number` |  |
| `boundsX`  (optional) | `number` | Element bounding box in viewport coordinates. |
| `boundsY`  (optional) | `number` |  |
| `boundsWidth`  (optional) | `number` |  |
| `boundsHeight`  (optional) | `number` |  |

 

 

 

#### `Antibot.locateElementAcrossFrames`

 Scrapfly 

Locates an element across ALL frames (main + iframes/OOPIFs).
Tries main frame first, then walks child frames until found.
Returns bounding box in main-frame CSS viewport coordinates.
Supports css, xpath, axNodeId, coord, and role selector types (not bottom).

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` | Supports css, xpath, axNodeId, coord, and role types. Not bottom. |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` |  |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |
| `pointX`  (optional) | `number` |  |
| `pointY`  (optional) | `number` |  |
| `boundsX`  (optional) | `number` |  |
| `boundsY`  (optional) | `number` |  |
| `boundsWidth`  (optional) | `number` |  |
| `boundsHeight`  (optional) | `number` |  |

 

 

 

#### `Antibot.waitForElement`

 Scrapfly 

Waits for a selector to appear in any frame (main + iframes/OOPIFs).
Polls natively via Mojo every 200ms (no JS execution). Searches main
frame first, then child frames on each poll cycle.
Supports css, xpath, axNodeId, coord, and role selector types (not bottom).

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `timeout`  (optional) | `integer` | Timeout in milliseconds. Default: 10000 (10s). |
| `visible`  (optional) | `boolean` | If true, also checks that the element has non-zero bounding box dimensions (width &gt; 0 and height &gt; 0). Note: does NOT check CSS visibility, display, or opacity properties. Default: false (just checks existence in the DOM). |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |
| `frameId`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Page#type-FrameId">Page.FrameId</a>` | Reserved for future use. Currently always null. |

 

 

 

#### `Antibot.getMousePosition`

 Scrapfly 

Returns the current tracked mouse position in CSS viewport pixels.

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `x` | `number` |  |
| `y` | `number` |  |

 

 

 

#### `Antibot.isElementVisible`

 Scrapfly 

Checks whether an element is visible in the viewport.
Only "css" and "xpath" selector types are supported.
Searches main frame first, then child frames (iframes/OOPIFs).
Visibility is determined by the renderer (checks display, opacity,
dimensions, and viewport intersection).

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` | Only css and xpath selector types are supported. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `visible` | `boolean` |  |
| `exists`  (optional) | `boolean` | True if element exists in the DOM but is hidden (not visible). |
| `reason`  (optional) | `string` | Human-readable reason when not visible (e.g. "zero size", "off viewport"). |

 

 

 

#### `Antibot.pressKey`

 Scrapfly 

Sends a single key press with human-like timing (keyDown + keyUp,
30-70ms hold duration).

Special key names (case-insensitive):
 "Enter", "Tab", "Escape" (or "Esc"), "Backspace", "Delete",
 "Space", "Home", "End", "PageUp", "PageDown",
 "ArrowUp" (or "Up"), "ArrowDown" (or "Down"),
 "ArrowLeft" (or "Left"), "ArrowRight" (or "Right")

Single characters: any single character (e.g. "a", "A", "1", "@").
Shift is applied automatically when the character requires it.

Modifier combos: prefix with "Ctrl+", "Shift+", "Alt+", or "Meta+"
(case-insensitive). One modifier prefix per call.
Examples: "Ctrl+a", "Ctrl+c", "Ctrl+v", "Shift+Tab", "Alt+F4"

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `key` | `string` | Key name, single character, or modifier combo. See above for accepted values. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

#### `Antibot.hover`

 Scrapfly 

Moves mouse to element with human-like trajectory and pauses
briefly to trigger hover states (CSS :hover, tooltips, menus).
Supports all selector types except bottom.

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` |  |
| `relativePosition`  (optional) | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Coordinate">Coordinate</a>` |  |
| `holdTime`  (optional) | `integer` | How long to hold the hover position in milliseconds. Default: random between 500 and 1500ms. |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |

 

 

 

: clicks the element, then selects the option via the browser's native popup. fires change/input events. for custom dropdowns (bootstrap, react select, mui, etc.): provide optionselector — the command will click the trigger to open the dropdown, find the matching option element, and click it. matching: provide exactly one of value, text, or index. for native : - "value" matches the  value attribute - "text" matches the  text content (whitespace-stripped) - "index" matches by 0-based position for custom dropdowns with optionselector: - "text" matches against option element's textcontent - "index" matches by 0-based position among matched elements - if optionselector already includes an attribute filter (e.g. ".dropdown-item\[data-value='us'\]"), the first match is clicked"&gt; #### `Antibot.selectOption`

 Scrapfly 

Selects an option in a &lt;select&gt; or custom dropdown.
Only "css" and "xpath" selector types are supported.

For native &lt;select&gt;: clicks the element, then selects the option
via the browser's native popup. Fires change/input events.

For custom dropdowns (Bootstrap, React Select, MUI, etc.): provide
optionSelector — the command will click the trigger to open the dropdown,
find the matching option element, and click it.

Matching: provide exactly one of value, text, or index.
For native &lt;select&gt;:
\- "value" matches the &lt;option&gt; value attribute
\- "text" matches the &lt;option&gt; text content (whitespace-stripped)
\- "index" matches by 0-based position
For custom dropdowns with optionSelector:
\- "text" matches against option element's textContent
\- "index" matches by 0-based position among matched elements
\- If optionSelector already includes an attribute filter
 (e.g. ".dropdown-item\[data-value='US'\]"), the first match is clicked

###### Parameters

 | Name | Type | Description |
|---|---|---|
| `selector` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-Selector">Selector</a>` | Only css and xpath selector types are supported. |
| `value`  (optional) | `string` | Select by option value attribute. Native &lt;select&gt; only. |
| `text`  (optional) | `string` | Select by visible text content (whitespace-stripped comparison). |
| `index`  (optional) | `integer` | Select by 0-based index among options. |
| `optionSelector`  (optional) | `string` | CSS selector for option elements in a custom dropdown. When provided, triggers click-based selection flow: 1. Click the trigger element (selector) to open the dropdown 2. Wait for elements matching optionSelector to appear in the DOM 3. Find the option matching text/index, or click the first match  if the selector already includes an attribute filter 4. Click the matching option element Examples: ".dropdown-item", "\[role=option\]", "li\[data-value='US'\]" |

 

###### Return Object

 | Name | Type | Description |
|---|---|---|
| `success` | `boolean` |  |
| `errorMessage`  (optional) | `string` |  |
| `selectedValue`  (optional) | `string` | The value of the selected option. |
| `selectedText`  (optional) | `string` | The text of the selected option. |

 

 

 

#### `Antibot.disable`

 Scrapfly 

Disables the Antibot domain.

 

 

 

## Types

#### `SelectorType`

 (string) Scrapfly 

How to locate an element. Not all commands support all types;
see each command's documentation for supported selector types.

###### Allowed Values

- `css`
- `xpath`
- `axNodeId`
- `coord`
- `role`
- `bottom`
 
 

 

#### `Selector`

 (object) Scrapfly 

Element selector — a type + query pair.
The query format depends on the type:
 css — CSS selector, e.g. "#btn", "input\[name='email'\]"
 xpath — XPath expression, e.g. "//div\[@id='main'\]"
 axNodeId — integer AX node ID as string, e.g. "42"
 coord — "x,y" comma-separated CSS viewport pixels, e.g. "450,600"
 role — AX role name (case-insensitive), e.g. "checkbox", "button"
 bottom — no query needed (pass ""). Only valid for scroll.
Not all commands support all selector types; see each command's docs.

###### Properties

 | Name | Type | Description |
|---|---|---|
| `type` | `<a href="/docs/cloud-browser-api/cdp-reference/Antibot#type-SelectorType">SelectorType</a>` |  |
| `query` | `string` |  |

 

 

 

#### `Coordinate`

 (object) Scrapfly 

A point in CSS viewport pixels.

###### Properties

 | Name | Type | Description |
|---|---|---|
| `x` | `number` |  |
| `y` | `number` |  |

 

 

 

#### `Rect`

 (object) Scrapfly 

A rectangle in CSS viewport pixels.

###### Properties

 | Name | Type | Description |
|---|---|---|
| `x` | `number` |  |
| `y` | `number` |  |
| `width` | `number` |  |
| `height` | `number` |  |

 

 

 

#### `FrameInfo`

 (object) Scrapfly 

Frame metadata returned by getFrames.

###### Properties

 | Name | Type | Description |
|---|---|---|
| `frameId` | `<a href="/docs/cloud-browser-api/cdp-reference/Page#type-FrameId">Page.FrameId</a>` |  |
| `url` | `string` |  |
| `origin` | `string` |  |
| `frameName` | `string` |  |
| `isMainFrame` | `boolean` | Whether this is the main frame. |
| `isOopif` | `boolean` | Whether this frame is an out-of-process iframe (OOPIF). |