Arc Browser MCP
Provides tools for inspecting and controlling Arc Browser spaces, tabs, and history on macOS, including reading sidebar data, creating/navigating/closing tabs, focusing spaces, and optionally executing JavaScript in tabs.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Arc Browser MCPlist tabs in my Research space"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Arc Browser MCP
Arc Browser MCP is a local stdio MCP server for inspecting and controlling Arc Browser Spaces and tabs on macOS.
It gives MCP clients such as Codex, Claude Code, opencode, and Claude Desktop a structured way to read Arc's local sidebar/history data and perform explicit Arc actions like focusing Spaces, selecting tabs, creating tabs, navigating tabs, reloading tabs, closing tabs, and optionally executing JavaScript.
Why This Exists
I built this because my Arc setup had become a very specific kind of personal knowledge system: lots of tabs, spread across lots of Spaces, quietly standing in for bookmarks, reading lists, project context, and things I was definitely going to deal with later.
That works until it does not. Once the browser becomes both workspace and storage, it gets hard to tell what is still useful, what is duplicated, what belongs in a second brain, and what can finally be closed. Arc Browser MCP makes that state legible to local agents so they can help inspect, search, organize, summarize, save, and clean up tabs with explicit user-controlled actions.
Arc automation is useful for focused browser actions, but it is not the best source for a complete, background-safe inventory of Spaces, folders, pinned and unpinned tabs, and history. In local testing with my Arc profile, reading all tabs through Arc automation could take up to 30 seconds; reading the same state from Arc's local JSON files took less than 10 ms, over 3,000x faster. Mutations use Arc automation because those changes take effect immediately without requiring a browser restart.
Tools
The server exposes compact v2 tools grouped by behavior. Read tools inspect local Arc data and do not intentionally change visible browser state. Create, edit, and delete tools automate Arc and can change what is visible in the browser.
Read Tools
Tool | Description |
| Returns a compact inventory of Arc Spaces, tab counts, pinned/unpinned counts, folder counts, missing URL counts, duplicate counts, and source warnings. |
| Lists, filters, and searches active Arc tabs using the local Arc index. Supports |
| Returns a full normalized tab record for an explicit |
| Returns the Space, pinned, unpinned, and folder hierarchy. Set |
| Searches local Arc Chromium history snapshots across profiles. Supports |
| Analyzes tabs for |
Create Tools
Tool | Description |
| Creates a new tab in an explicit Arc Space. Requires |
Edit And Navigation Tools
Tool | Description |
| Focuses an Arc Space by explicit |
| Selects an Arc tab by explicit |
| Navigates a specific tab when |
| Reloads one or more tabs by explicit |
| Executes JavaScript in an explicit tab. Disabled by default and available only when |
Delete Tools
Tool | Description |
| Closes one or more tabs by explicit |
Find duplicate tabs:
{
"analyses": ["duplicates"],
"limit": 25,
"include_evidence": true
}Search tabs in a Space:
{
"query": "docs",
"space_id": "space-id",
"limit": 20
}Create a tab in a known Space:
{
"space_id": "space-id",
"url": "https://example.com",
"select": true
}Preview closing tabs:
{
"tab_ids": ["tab-id-1", "tab-id-2"],
"dry_run": true
}Close tabs after review:
{
"tab_ids": ["tab-id-1", "tab-id-2"],
"dry_run": false
}Quick Start
Requirements:
macOS
Arc installed at
/Applications/Arc.appPython 3.12 or newer
uv/uvxA local stdio MCP client
macOS Automation permission for the MCP client or terminal app when using mutating tools
Run the server directly:
uvx arc-browser-mcpRun a local prerequisite check:
uvx arc-browser-mcp doctorInstallation
codex mcp add arc-browser -- uvx arc-browser-mcpclaude mcp add --transport stdio --scope user arc-browser -- uvx arc-browser-mcpAdd this server entry to ~/.config/opencode/opencode.json or a project
opencode.json:
{
"$schema": "https://opencode.ai/config.json",
"mcp": {
"arc_browser": {
"type": "local",
"command": ["uvx", "arc-browser-mcp"],
"enabled": true,
"timeout": 10000
}
}
}For local development, add this to the Claude Desktop MCP config:
{
"mcpServers": {
"arc-browser": {
"command": "uvx",
"args": ["arc-browser-mcp"],
"env": {}
}
}
}For end users, prefer a Claude Desktop Extension / DXT package. This repository includes MCPB packaging metadata for that workflow:
npm install -g @anthropic-ai/mcpb
mcpb packFrom a checkout of this repository:
uv sync
uv run arc-browser-mcp doctor
uv run arc-browser-mcp serveFor a local MCP client config that runs from source, use:
uv run arc-browser-mcpor:
uv run arc-browser-mcp serveYou can also print client-specific install guidance:
uvx arc-browser-mcp install --client codex
uvx arc-browser-mcp install --client claude-code
uvx arc-browser-mcp install --client opencode
uvx arc-browser-mcp install --client claude-desktopSafety And Privacy
The server is local and communicates with MCP clients over stdio.
Read tools may return private browser data to the connected MCP client, including titles, URLs, domains, Space names, folder names, profile IDs, history metadata, and local source paths.
The server does not send browser data anywhere by itself. Your MCP client and its model provider receive whatever data they request through tool calls.
Mutating tools change visible Arc state, including focused Spaces, selected tabs, newly created tabs, opened URLs, reloaded tabs, and closed tabs.
Destructive actions require explicit tab IDs.
arc_close_tabsalso supportsdry_run.arc_create_tabrequires an explicit Space ID and verifies the created tab before returning its ID.arc_execute_javascriptis disabled unlessARC_MCP_ENABLE_JAVASCRIPT=1is set in the MCP server environment.The server does not directly edit Arc sidebar, archive, command ranking, or history files. Changes go through Arc automation instead.
Reference
Less common setup, debugging, and development details live here.
arc-browser-mcp serve
arc-browser-mcp doctor
arc-browser-mcp smoke --read-only
arc-browser-mcp install --client codex
arc-browser-mcp install --client claude-code
arc-browser-mcp install --client opencode
arc-browser-mcp install --client claude-desktopserve runs the MCP server over stdio. Running arc-browser-mcp without a
subcommand also starts the server.
doctor checks macOS, osascript, uvx, and the expected Arc app location.
smoke --read-only runs live read-only checks against local Arc state. It does
not call mutating tools.
install --client ... prints MCP configuration guidance for a supported client.
Arc Is Not Running
Mutating tools and live Arc reads through AppleScript/JXA require Arc to be running. Open Arc and retry the tool call.
macOS Automation Permission Is Denied
If Arc actions fail with an automation or permissions error, open macOS System Settings and check the Automation and Privacy & Security permissions for the terminal or MCP client that launches this server.
uvx Is Missing
Install uv from the official installer or package manager you use, then rerun:
arc-browser-mcp doctorJavaScript Execution Is Disabled
arc_execute_javascript intentionally fails unless enabled:
ARC_MCP_ENABLE_JAVASCRIPT=1 uvx arc-browser-mcpOnly enable this in a client configuration where you are comfortable allowing explicit JavaScript execution in browser tabs.
Multiple Arc Windows
Some tools accept window_id. Use arc_get_overview, arc_query_tabs, or a
client-visible tab record to identify Space and tab IDs first. When creating a
tab and more than one Arc window is open, pass window_id when you need the tab
created in a specific window.
Set up the local environment:
uv syncRun tests and linting:
uv run pytest
uv run ruff check .Run local checks against Arc:
uv run arc-browser-mcp doctor
uv run arc-browser-mcp smoke --read-onlyRun the server from source:
uv run arc-browser-mcp serveManual live verification steps are documented in
docs/manual-verification.md.
The repository includes manifest.json and .mcpbignore for MCPB packaging:
npm install -g @anthropic-ai/mcpb
mcpb packLicense
MIT. See LICENSE.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/jasoncronje/arc-browser-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server