Browser overview
Browser support enables agents to navigate websites, interact with page elements, fill forms, and extract data. Mastra provides browser capabilities through SDK providers that wrap popular browser automation libraries.
Mastra supports two browser SDK providers:
- AgentBrowser: A Playwright-based provider with accessibility-first element targeting. Best for general web automation and scraping.
- Stagehand: A Browserbase provider with AI-powered element detection. Best for complex interactions that benefit from natural language selectors.
When to use browserDirect link to When to use browser
Use browser when your agent needs to:
- Navigate websites and interact with page elements
- Fill out forms and submit data
- Extract structured data from web pages
- Automate multi-step web workflows
- Take actions that require a real browser (JavaScript rendering, authentication flows)
How it worksDirect link to How it works
When you assign a browser to an agent, Mastra includes the provider's tools in the agent's toolset. The agent uses these tools to control the browser: navigating to URLs, selecting elements, typing text, and reading page content.
Each provider offers a different set of tools optimized for its approach.
QuickstartDirect link to Quickstart
Install your provider of choice, for this example you'll use the AgentBrowser provider.
- npm
- pnpm
- Yarn
- Bun
npm install @mastra/agent-browser
pnpm add @mastra/agent-browser
yarn add @mastra/agent-browser
bun add @mastra/agent-browser
Create a new browser instance:
import { AgentBrowser } from '@mastra/agent-browser'
export const browser = new AgentBrowser({
headless: false,
})
Assign the browser to an agent:
import { Agent } from '@mastra/core/agent'
import { browser } from '../browsers'
export const webAgent = new Agent({
id: 'web-agent',
model: 'openai/gpt-5.4',
browser,
instructions:
'You are a web automation assistant. Use browser tools to navigate websites and complete tasks.',
})
The agent automatically receives all browser tools from the provider.
Cloud providersDirect link to Cloud providers
Both SDK providers support connecting to cloud browser services instead of launching a local browser.
Browserbase (Stagehand native)Direct link to Browserbase (Stagehand native)
Stagehand has native Browserbase integration:
import { StagehandBrowser } from '@mastra/stagehand'
const browser = new StagehandBrowser({
env: 'BROWSERBASE',
apiKey: process.env.BROWSERBASE_API_KEY,
projectId: process.env.BROWSERBASE_PROJECT_ID,
})
CDP URL (any provider)Direct link to CDP URL (any provider)
Connect to any browser exposing a Chrome DevTools Protocol (CDP) endpoint:
import { AgentBrowser } from '@mastra/agent-browser'
const browser = new AgentBrowser({
cdpUrl: process.env.BROWSER_CDP_URL,
headless: true,
})
This works with any CDP-compatible browser service.
ScreencastDirect link to Screencast
Browser providers stream a live video feed of the browser to the Mastra Studio UI. This lets you watch the agent interact with pages in real-time.
Screencast is enabled by default and can be configured:
const browser = new AgentBrowser({
screencast: {
enabled: true,
format: 'jpeg',
quality: 80,
maxWidth: 1280,
maxHeight: 720,
},
})