MCP server for Vibe AI Browser - the only browser automation tool that supports multiple AI agents simultaneously.
Paste the block below into your OpenClaw or Hermes agent. Replace the last line with your remote value — a UUID or a wss://relay.api.vibebrowser.app/<uuid> URL from the Vibe extension's Settings → AI Agent Control → Remote (internet) → Relay access. That's the only edit you make.
You are setting yourself up to control my real Chrome through Vibe Browser. Work through the steps in order, and after each step confirm it worked before moving on. Do not claim a step is done until you have proven it.
1. Install the "vibebrowser" skill for your runtime:
- OpenClaw: npx -y skills add VibeTechnologies/vibe-mcp -s vibebrowser -a openclaw -g -y --copy --dangerously-accept-openclaw-risks
then run `openclaw skills list` and confirm a "vibebrowser" row shows "ready" as installer registration.
- Hermes: npx -y skills add VibeTechnologies/vibe-mcp -s vibebrowser -y
optional installer registration check: `npx -y skills list` shows a "vibebrowser" row.
2. Remember my remote so I only give it to you once. Save it to a file `vibebrowser-cli.md` in your persistent agent workspace root (the directory that holds your `memory/` folder — not the shell's working dir, not $HOME unless they are the same) as a line `remote: <value>`; if your runtime can also write memory keys, additionally store it under `vibebrowser_remote`. On every later command — including the first message of a new conversation — load it back from that file and reuse it without asking me again.
3. Record a standing rule so you route correctly later: whenever I ask you to do anything in MY browser / MY Chrome / MY tabs / the page I'm on, use this vibebrowser skill (`npx -y @vibebrowser/cli@latest` with my saved remote) to drive my REAL browser — never your built-in, headless, or in-pod browser, never web-fetch instead, and never run `vibebrowser`. Save this rule wherever your standing instructions/memory live so it applies in future conversations.
4. Confirm you can control my Chrome, retrying on "Extension reconnecting" (wait 3s, up to 5x):
npx -y @vibebrowser/cli@latest --remote "<my remote>" --json status --wait-for-extension --wait-timeout 20000
npx -y @vibebrowser/cli@latest --remote "<my remote>" --json snapshot --format aria
Then report: (1) is extensionConnected true, (2) did the snapshot return my real page content?
My remote: <PASTE YOUR UUID OR wss:// URL HERE>
| Feature | Vibe MCP | Playwright MCP | BrowserMCP |
|---|---|---|---|
| Multi-Agent Support | Yes | No | No |
| Uses Your Browser Profile | Yes | No | No |
| Logged-In Sessions | Yes | No | No |
| No Separate Browser | Yes | No | No |
| Local & Private | Yes | Yes | Partial |
| Content Script Based | Yes | No | No |
Vibe MCP is the only solution that allows multiple AI agents to control the same browser simultaneously. Run Claude Desktop, Cursor, VS Code Copilot, and OpenCode all at once - they all share control of your browser through our relay architecture.
Claude Desktop Cursor VS Code OpenCode
| | | |
v v v v
[vibebrowser-mcp] [vibebrowser-mcp] [vibebrowser-mcp] [vibebrowser-mcp]
| | | |
+------------------+----------------+---------------+
|
v
[Relay Daemon] <-- Auto-spawned, handles multiplexing
|
v
[Vibe Extension]
|
v
[Your Chrome]
Competitors like Playwright MCP and BrowserMCP fail when you try to run multiple agents - they get port conflicts or connection errors. Vibe MCP just works.
- Multi-Agent Ready - Run Claude, Cursor, VS Code, and more simultaneously
- Uses Your Browser - No separate browser instance, uses your existing Chrome with all your logins
- Fast & Local - Automation happens on your machine, no cloud latency
- Private - Your browsing data never leaves your device
- Stable - Content script based, no flaky CDP connections
- Direct Chrome DevTools mode - Extension tools stay primary by default; use
--devtoolsto drive your real running Chrome directly over the DevTools Protocol (no extension required)
Install the Vibe AI Browser extension in Chrome, Brave, or any Chromium browser:
Option A: Chrome Web Store (Recommended)
- Visit the Chrome Web Store
- Click "Add to Chrome"
- The Vibe icon will appear in your toolbar
Option B: Developer Version
- Download the latest release ZIP
- Extract to a permanent folder
- Go to
chrome://extensions, enable Developer Mode - Click "Load unpacked" and select the extracted folder
For detailed instructions, see the installation guide.
Claude Desktop
Edit your Claude Desktop config file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp"]
}
}
}Restart Claude Desktop after saving.
Cursor
- Open Cursor Settings (Cmd/Ctrl + ,)
- Go to "Features" -> "MCP Servers"
- Click "Add Server" and add:
{
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp"]
}
}Or edit ~/.cursor/mcp.json directly.
VS Code (GitHub Copilot)
Add to your VS Code settings.json:
{
"github.copilot.chat.mcpServers": {
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp"]
}
}
}Windsurf
Edit ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp"]
}
}
}OpenCode
Add to your .opencode/config.json:
{
"mcp": {
"servers": {
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp"]
}
}
}
}Gemini CLI
Add to ~/.gemini/settings.json:
{
"mcpServers": {
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp"]
}
}
}OpenAI Codex CLI
Add to your Codex configuration:
{
"mcp": {
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp"]
}
}
}Use the shortest direct package invocation for the MCP server:
npx -y @vibebrowser/mcp@latest --help
npx -y @vibebrowser/mcp@latest start --transport http
npx -y @vibebrowser/mcp@latest openclaw --remote "$VIBE_REMOTE_UUID"Backward-compatible aliases still work when you need explicit binaries:
npx -y -p @vibebrowser/mcp@latest vibebrowser-mcp --help
npx -y -p @vibebrowser/mcp@latest vibe-mcp --help- Open Chrome with the Vibe extension installed
- Click the Vibe extension icon in the toolbar
- Go to Settings and enable "MCP External Control"
- The status should show "Connected"
If the extension is not connected, vibebrowser-mcp can optionally fall back to
chrome-devtools-mcp (started in --autoConnect mode) when that package is installed.
This fallback runs once in the shared local relay daemon (multi-agent safe), so
both vibebrowser-mcp and vibebrowser-cli use the same backend instance.
When extension is connected, extension tools are authoritative.
Pass --devtools to either CLI to bypass relay/extension routing entirely and
drive your real running Chrome directly over the Chrome DevTools Protocol.
This backend (ported from the chrome-use skill) reads Chrome's
DevToolsActivePort file and autoConnects to your live profile — no extension,
no external MCP server, zero extra dependencies. Requires Chrome 144+; the
permission dialog fires once per profile.
--devtools exposes a focused tool set: navigate, snapshot (accessibility
tree with @eN refs), click, fill, type, press_key, hover, scroll,
screenshot, eval, get_text, get_url, get_title, and tab management
(list_tabs, new_tab, select_tab, close_tab). Use snapshot to get
@eN element refs, then pass them as selectors to click/fill/type.
Override the Chrome profile/channel with VIBE_CHROME_USER_DATA_DIR and
VIBE_CHROME_CHANNEL (stable | canary | beta | dev).
Not yet covered by --devtools v1 (addable later as more CDP domains are wired):
network request inspection, console logs, performance traces, Lighthouse, memory
snapshots, device emulation, dialog handling, file upload, and drag.
| Tool | Description |
|---|---|
navigate_to_url |
Navigate to any URL |
go_back / go_forward |
Browser history navigation |
click |
Click elements on the page |
type / fill |
Enter text into inputs |
scroll |
Scroll the page |
take_screenshot |
Capture screenshots |
get_page_content |
Extract page text/HTML |
get_tabs / create_new_tab / switch_to_tab / close_tab |
Tab management |
keyboard_shortcut |
Press keyboard combinations |
web_search |
Search the web |
Default local mode (no flags):
Claude / Cursor / VS Code (stdio)
│
▼
[vibebrowser-mcp]
│ ws://127.0.0.1:19888
▼
Local Relay (auto-spawned)
│ ws://127.0.0.1:19889
▼
Vibe Extension (Chrome)
- AI applications connect via MCP over stdio
vibebrowser-mcpconnects to the local relay on port19888- The relay forwards commands to the extension on port
19889 - Results flow back to the agent
When multiple agents connect, Vibe MCP automatically spawns a relay daemon:
- First agent starts the relay (listens on ports 19888 and 19889)
- Additional agents connect to the relay as clients
- Relay multiplexes all agent requests to the single extension connection
- Each agent receives only its own responses
If your agent runs in the cloud but you want it to control the user's real local browser, run vibebrowser-mcp in HTTP mode and connect it to the Vibe extension in remote relay mode. Pass either the extension UUID or the full WebSocket relay URL to --remote.
VIBE_REMOTE_UUID="YOUR-EXTENSION-UUID"
VIBE_REMOTE_URL="wss://relay.api.vibebrowser.app/YOUR-EXTENSION-UUID"
npx -y @vibebrowser/mcp@latest start --transport http --remote "$VIBE_REMOTE_UUID"
npx -y @vibebrowser/mcp@latest start --transport http --remote "$VIBE_REMOTE_URL"This exposes a local MCP endpoint at http://127.0.0.1:8788/mcp by default.
When OpenClaw runs on a different machine (for example cloud-hosted), provide a reachable URL:
VIBE_REMOTE_UUID="YOUR-EXTENSION-UUID"
VIBE_REMOTE_URL="wss://relay.api.vibebrowser.app/YOUR-EXTENSION-UUID"
PUBLIC_MCP_URL="https://browser-bridge.example.com/mcp"
npx -y @vibebrowser/mcp@latest openclaw --remote "$VIBE_REMOTE_UUID" --public-url "$PUBLIC_MCP_URL"
npx -y @vibebrowser/mcp@latest openclaw --remote "$VIBE_REMOTE_URL" --public-url "$PUBLIC_MCP_URL"You can print the exact OpenClaw-friendly setup with:
VIBE_REMOTE_UUID="YOUR-EXTENSION-UUID"
VIBE_REMOTE_URL="wss://relay.api.vibebrowser.app/YOUR-EXTENSION-UUID"
npx -y @vibebrowser/mcp@latest openclaw --remote "$VIBE_REMOTE_UUID"
npx -y @vibebrowser/mcp@latest openclaw --remote "$VIBE_REMOTE_URL"Use --remote <uuid> with the default public relay, or --remote <full-ws-url> when you need an explicit relay endpoint.
For direct browser CLI checks, always use npx -y @vibebrowser/cli@latest:
VIBE_REMOTE_UUID="YOUR-EXTENSION-UUID"
VIBE_REMOTE_URL="wss://relay.api.vibebrowser.app/YOUR-EXTENSION-UUID"
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_UUID" --json status
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_URL" --json status--remote <uuid> uses the default public relay. --remote <full-ws-url> targets an explicit relay endpoint.
For the full walkthrough, see docs/openclaw-local-browser.md.
npx -y @vibebrowser/cli@latest mirrors the OpenClaw browser CLI shape for the real local-browser path:
npx -y @vibebrowser/cli@latest sessions
VIBE_REMOTE_UUID="YOUR-EXTENSION-UUID"
VIBE_REMOTE_URL="wss://relay.api.vibebrowser.app/YOUR-EXTENSION-UUID"
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_UUID" status
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_URL" tabs
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_UUID" open https://example.com
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_URL" snapshot
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_UUID" click 12
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_URL" type 23 "hello" --submit
npx -y @vibebrowser/cli@latest --devtools statusUse the MCP package for MCP server workflows and the CLI package for direct browser control:
vibebrowser-mcpfor MCP server, HTTP bridge, and helper commandsnpx -y @vibebrowser/cli@latestfor OpenClaw-inspired browser control against the real Vibe-connected session
@vibebrowser/cli accepts the OpenClaw-style --browser-profile flag for compatibility and supports --json for machine-readable output. Unlike OpenClaw's managed openclaw browser profile, this CLI always targets the real Vibe-connected browser session.
Local-session selection:
npx -y @vibebrowser/cli@latest sessionslists connected local browser sessions.npx -y @vibebrowser/cli@latest --session <id> ...targets a specific local session.- If
--sessionis omitted in local mode, the CLI uses the first connected session. - In remote mode, pass either
--remote <uuid>to use the default public relay or--remote <full-ws-url>to use an explicit relay endpoint.
Snapshot behavior is tool-only (no legacy snapshot RPC shortcut):
snapshot(default,--format ai) resolves via thetake_md_snapshottool — uses the content script's in-page markdown extractor. Fast and readable, but may return empty for background tabs or complex SPAs (Notion, Gmail) where the content script is unreachable or layout is not computed.snapshot --format ariaresolves via thetake_a11y_snapshottool — uses Chrome DevTools ProtocolAccessibility.getFullAXTreedirectly. Reliable for all tabs including background tabs and SPAs. Use this as a fallback when the default format returns empty or only a page title.
This keeps CLI behavior aligned with extension-supported tools and ensures page targeting works consistently with --page-id/--pageId.
For navigation-style operations, responses now include page content when page state changes:
- CLI
open/navigateincludepageContentin JSON output. - MCP tool calls for navigation-style tools return text content that includes current page state (with snapshot fallback when needed).
Use the single canonical copy-paste prompt at the top of this README:
Install prompt for AI agents (OpenClaw / Hermes).
It installs the vibebrowser skill, saves your remote so you only give it once, and proves
control of your real Chrome.
For a deeper skill definition (when to prefer this over a managed/headless browser, the remote-recall rules, selector/snapshot guidance), install openclaw/vibebrowser/SKILL.md into the agent's skills directory.
There are two ways to use Vibe with OpenClaw:
Option A: Cloud OpenClaw controlling local browser
If OpenClaw runs in the cloud but you want it to control your local browser:
- Install the Vibe extension and enable Remote mode (see docs/openclaw-local-browser.md)
- Start the local HTTP bridge:
vibebrowser-mcp openclaw --remote "$VIBE_REMOTE_UUID" [--public-url "$PUBLIC_MCP_URL"]orvibebrowser-mcp openclaw --remote "$VIBE_REMOTE_URL" [--public-url "$PUBLIC_MCP_URL"] - Register the MCP URL in OpenClaw
Option B: OpenClaw skill for local agents
For OpenClaw agents that need your real browser context (logged-in sessions, existing tabs):
- Copy the Vibe skill from this package to your OpenClaw skills folder
- Use the extension UUID or full WebSocket relay URL with
--remote - Use
npx -y @vibebrowser/cli@latestcommands in your agent prompts
The skill is located at openclaw/vibebrowser/SKILL.md and provides:
- Full OpenClaw-compatible CLI commands (
status,tabs,snapshot,click,type, etc.) - Fallback-safe commands for DevTools-backed flows (
resize,upload,dialog) --jsonoutput for machine parsing- Environment-based configuration
See docs/openclaw-local-browser.md for the complete walkthrough.
Run a local LLM with one command — no cloud API keys required. Automatically installs Ollama, downloads the model, and starts serving an OpenAI-compatible API.
npx -y @vibebrowser/mcp@latest serve qwen3.5That's it. Works on macOS, Linux, and Windows.
- Detects Ollama → installs it if missing (via
brew,curl, orwinget) - Starts the server → launches
ollama servein the background - Downloads the model → streams download progress to your terminal
- Prints connection info → ready to use with VibeBrowser or any OpenAI-compatible client
npx -y @vibebrowser/mcp@latest serve qwen3.5 # Best overall for agentic tasks
npx -y @vibebrowser/mcp@latest serve llama4 # Strong general reasoning
npx -y @vibebrowser/mcp@latest serve deepseek-r1 # Reasoning chains
npx -y @vibebrowser/mcp@latest serve mistral # Lightweight & fast (7B)npx -y @vibebrowser/mcp@latest serve <model> [options]
Options:
-p, --port <number> Ollama API port (default: 11434)
-y, --yes Skip install confirmation prompts
-d, --debug Enable debug logging
After serve completes, configure the extension:
- Model provider →
ollama - Model name → the model you served (e.g.,
qwen3.5)
The extension connects to http://localhost:11434/v1 automatically.
npx -y @vibebrowser/mcp@latest --help
npx -y @vibebrowser/cli@latest --help
# MCP server (default)
npx -y @vibebrowser/mcp@latest [start] [options]
-p, --port <number> WebSocket port for local relay (agent) connection (default: 19888)
-d, --debug Enable debug logging
--transport <mode> MCP transport to expose: stdio or http (default: stdio)
--host <host> Host to bind the HTTP server to (default: 127.0.0.1)
--http-port <number> Port for streamable HTTP MCP transport (default: 8788)
--http-path <path> Path for streamable HTTP MCP transport (default: /mcp)
--allow-host <host> Allowed host header for HTTP transport (repeatable)
-r, --remote <uuid-or-url> Extension UUID, or full ws(s) remote URL
--devtools Drive your real running Chrome directly over the DevTools Protocol (bypasses the extension relay)
# MCP server tool
set_remote { "url": "wss://relay.api.vibebrowser.app/<extension-uuid>" }
The set_remote MCP server tool hot-reconnects the running MCP server to a different remote relay URL. It is an MCP tool, not a browser CLI subcommand.
# OpenClaw helper
VIBE_REMOTE_UUID="YOUR-EXTENSION-UUID"
VIBE_REMOTE_URL="wss://relay.api.vibebrowser.app/YOUR-EXTENSION-UUID"
PUBLIC_MCP_URL="https://browser-bridge.example.com/mcp"
npx -y @vibebrowser/mcp@latest openclaw --remote "$VIBE_REMOTE_UUID" --public-url "$PUBLIC_MCP_URL"
npx -y @vibebrowser/mcp@latest openclaw --remote "$VIBE_REMOTE_URL" --public-url "$PUBLIC_MCP_URL"
# OpenClaw-compatible browser CLI
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_UUID" status
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_URL" status --wait-for-extension --wait-timeout 10000
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_UUID" tabs
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_URL" snapshot --json
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_UUID" click 12
npx -y @vibebrowser/cli@latest --remote "$VIBE_REMOTE_URL" type 23 "hello" --submit
npx -y @vibebrowser/cli@latest --devtools tabs
# Local LLM server
MODEL="qwen3.5"
npx -y @vibebrowser/mcp@latest serve "$MODEL"
-p, --port <number> Ollama API port (default: 11434)
-y, --yes Skip confirmation prompts
-d, --debug Enable debug logging- Ensure the Vibe extension is installed in Chrome
- Click the extension icon and enable "MCP External Control" in Settings
- Check that no firewall is blocking localhost connections
- Start
vibebrowser-mcpin HTTP mode instead of stdio - Make sure the bridge process is still running on the user's machine
- Confirm the extension is in
Remotemode and connected - Verify the MCP URL in OpenClaw matches the bridge URL. If OpenClaw is cloud-hosted, do not use
127.0.0.1; useopenclaw --public-urlwith a reachable host.
Enable debug logging to diagnose issues:
{
"mcpServers": {
"vibe": {
"command": "npx",
"args": ["-y", "@vibebrowser/mcp", "--debug"]
}
}
}git clone https://github.com/VibeTechnologies/vibe-mcp.git
cd vibe-mcp
npm install
npm run build
node dist/cli.js --debugbrowser automation, mcp server, model context protocol, ai browser control, claude desktop browser, cursor browser automation, web automation, chrome automation, ai agent browser, multi-agent browser control, playwright alternative, puppeteer alternative, browser mcp, web scraping ai, ai web agent
Apache-2.0
- Vibe AI Browser - Main product
- Documentation - Full docs
- Chrome Extension - Install extension
- GitHub Issues - Report bugs
- npm Package - npm registry