Safari MCP

Native Safari browser automation for AI agents โ€” 80 tools via AppleScript, zero Chrome overhead, keeps logins. macOS only.

Safari MCP Server โ€” 80 native browser automation tools for AI agents on macOS

๐Ÿฆ Safari MCP

The browser for your coding agent.

Your real Safari, logged in โ€” no Chrome, no heat, no headless.

npm version npm downloads License: MIT macOS

Glama AAA MCP Registry Smithery MCP Score

Install in VS Code Install in VS Code Insiders Install in Cursor

80 tools ยท No Chrome/Puppeteer/Playwright needed ยท ~5ms per command ยท 60% less CPU than Chrome

Quick Start ยท All 80 Tools ยท Examples ยท Why Safari MCP? ยท Architecture ยท Changelog

Safari MCP Demo

โŒ Without Safari MCP

Your AI agent needs to browse. So it either:

  • Spins up Chromium via Playwright โ€” with no logins, no cookies, no sessions
  • Uses Chrome DevTools MCP โ€” and melts your fan running a second browser
  • Relies on headless scrapers โ€” blocked by Cloudflare, reCAPTCHA, and bot detection

โœ… With Safari MCP

Your AI drives the Safari you're already logged into โ€” Gmail, GitHub, Ahrefs, Slack, banking.

Native WebKit. ~60% less CPU. Background operation. 80 tools. One npx command. macOS only.

๐Ÿ“ฐ Featured on HackerNoon: I Had to Reverse-Engineer React, Shadow DOM, and CSP to Automate Safari Without Chrome


Highlights

  • 80 tools โ€” navigation, clicks, forms, screenshots, network, storage, accessibility, and more
  • Zero heat โ€” native WebKit on Apple Silicon, ~60% less CPU than Chrome
  • Your real browser โ€” keeps all logins, cookies, sessions (Gmail, GitHub, Ahrefs, etc.)
  • Background operation โ€” Safari stays in the background, no window stealing
  • No browser dependencies โ€” no Puppeteer, no Playwright, no WebDriver, no Chrome
  • Persistent process โ€” reuses a single osascript process (~5ms per command vs ~80ms)
  • Framework-compatible โ€” React, Vue, Angular, Svelte form filling via native setters

Quick Start

Prerequisites

  • macOS (any version with Safari)
  • Node.js 18+
  • Safari โ†’ Settings โ†’ Advanced โ†’ Show features for web developers โœ“
  • Safari โ†’ Develop โ†’ Allow JavaScript from Apple Events โœ“

Install (one command)

npx safari-mcp

That's it โ€” no global install needed. Or install permanently:

npm install -g safari-mcp

Configure your MCP client

All clients run Safari MCP the same way โ€” npx safari-mcp. Pick your editor:

Claude Code
claude mcp add safari -- npx safari-mcp

Or edit ~/.mcp.json:

{
  "mcpServers": {
    "safari": {
      "command": "npx",
      "args": ["safari-mcp"]
    }
  }
}
Claude Desktop

Edit ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "safari": {
      "command": "npx",
      "args": ["safari-mcp"]
    }
  }
}

Restart Claude Desktop after saving.

Cursor

One-click: Install in Cursor

Or edit .cursor/mcp.json in your project:

{
  "mcpServers": {
    "safari": {
      "command": "npx",
      "args": ["safari-mcp"]
    }
  }
}
VS Code / VS Code Insiders

One-click: Install in VS Code

Or edit .vscode/mcp.json:

{
  "servers": {
    "safari": {
      "type": "stdio",
      "command": "npx",
      "args": ["safari-mcp"]
    }
  }
}
Windsurf

Edit .windsurf/mcp.json in your project (or ~/.codeium/windsurf/mcp_config.json globally):

{
  "mcpServers": {
    "safari": {
      "command": "npx",
      "args": ["safari-mcp"]
    }
  }
}
Cline

Open Cline in VS Code โ†’ click the MCP icon โ†’ Edit MCP Settings โ†’ add:

{
  "mcpServers": {
    "safari": {
      "command": "npx",
      "args": ["safari-mcp"]
    }
  }
}
Continue

Edit ~/.continue/config.yaml (or .continue/config.yaml in workspace):

mcpServers:
  - name: safari
    command: npx
    args:
      - safari-mcp
Goose

Edit ~/.config/goose/config.yaml:

extensions:
  safari:
    name: safari
    type: stdio
    cmd: npx
    args:
      - safari-mcp
    enabled: true
LM Studio

Open LM Studio โ†’ Settings โ†’ MCP Servers โ†’ Add Server:

  • Name: safari
  • Command: npx
  • Args: safari-mcp
Zed

Open Zed โ†’ Settings โ†’ search for "Context Servers" and add:

{
  "context_servers": {
    "safari": {
      "command": {
        "path": "npx",
        "args": ["safari-mcp"]
      }
    }
  }
}
Alternative: Homebrew
brew install achiya-automation/tap/safari-mcp
Alternative: from source
git clone https://github.com/achiya-automation/safari-mcp.git
cd safari-mcp && npm install

Usage Workflow

The recommended pattern for AI agents using Safari MCP:

1. safari_snapshot        โ†’ Get page state (accessibility tree)
2. safari_click/fill/...  โ†’ Interact with elements by ref
3. safari_snapshot        โ†’ Verify the result

Element targeting โ€” tools accept multiple targeting strategies:

StrategyExampleBest for
CSS selector#login-btn, .submitUnique elements
Visible text"Sign In", "Submit"Buttons, links
Coordinatesx: 100, y: 200Canvas, custom widgets
Ref from snapshotref: "e42"Any element from accessibility tree

Tip: Start with safari_snapshot to get element refs, then use refs for precise targeting. This is faster and more reliable than CSS selectors.


Tools (80)

Click to expand the full tool list โ€” organized by category

Navigation (4)

ToolDescription
safari_navigateNavigate to URL (auto HTTPS, wait for load)
safari_go_backGo back in history
safari_go_forwardGo forward in history
safari_reloadReload page (optional hard reload)

Page Reading (3)

ToolDescription
safari_read_pageGet title, URL, and text content
safari_get_sourceGet full HTML source
safari_navigate_and_readNavigate + read in one call

Click & Interaction (5)

ToolDescription
safari_clickClick by CSS selector, visible text, or coordinates
safari_double_clickDouble-click (select word, etc.)
safari_right_clickRight-click (context menu)
safari_hoverHover over element
safari_click_and_waitClick + wait for navigation

Form Input (7)

ToolDescription
safari_fillFill input (React/Vue/Angular compatible)
safari_clear_fieldClear input field
safari_select_optionSelect dropdown option
safari_fill_formBatch fill multiple fields
safari_fill_and_submitFill form + submit in one call
safari_type_textType real keystrokes (JS-based, no System Events)
safari_press_keyPress key with modifiers

Screenshots & PDF (3)

ToolDescription
safari_screenshotScreenshot as PNG (viewport or full page)
safari_screenshot_elementScreenshot a specific element
safari_save_pdfExport page as PDF

Scroll (3)

ToolDescription
safari_scrollScroll up/down by pixels
safari_scroll_toScroll to exact position
safari_scroll_to_elementSmooth scroll to element

Tab Management (4)

ToolDescription
safari_list_tabsList all tabs (index, title, URL)
safari_new_tabOpen new tab (background, no focus steal)
safari_close_tabClose tab
safari_switch_tabSwitch to tab by index

Wait (2)

ToolDescription
safari_wait_forWait for element, text, or URL change
safari_waitWait for specified milliseconds

JavaScript (1)

ToolDescription
safari_evaluateExecute arbitrary JavaScript, return result

Element Inspection (4)

ToolDescription
safari_get_elementElement details (tag, rect, attrs, visibility)
safari_query_allFind all matching elements
safari_get_computed_styleComputed CSS styles
safari_detect_formsAuto-detect all forms with field selectors

Accessibility (1)

ToolDescription
safari_accessibility_snapshotFull a11y tree: roles, ARIA, focusable elements

Drag & Drop (1)

ToolDescription
safari_dragDrag between elements or coordinates

File Operations (2)

ToolDescription
safari_upload_fileUpload file via JS DataTransfer (no file dialog!)
safari_paste_imagePaste image into editor (no clipboard touch!)

Dialog & Window (2)

ToolDescription
safari_handle_dialogHandle alert/confirm/prompt
safari_resizeResize browser window

Device Emulation (2)

ToolDescription
safari_emulateEmulate device (iPhone, iPad, Pixel, Galaxy)
safari_reset_emulationReset to desktop

Cookies & Storage (10)

ToolDescription
safari_get_cookiesGet all cookies
safari_set_cookieSet cookie with all options
safari_delete_cookiesDelete one or all cookies
safari_local_storageRead localStorage
safari_set_local_storageWrite localStorage
safari_delete_local_storageDelete/clear localStorage
safari_session_storageRead sessionStorage
safari_set_session_storageWrite sessionStorage
safari_delete_session_storageDelete/clear sessionStorage
safari_export_storageExport all storage as JSON (backup/restore sessions)
safari_import_storageImport storage state from JSON

Clipboard (2)

ToolDescription
safari_clipboard_readRead clipboard text
safari_clipboard_writeWrite text to clipboard

Network (6)

ToolDescription
safari_networkQuick network requests via Performance API
safari_start_network_captureStart detailed capture (fetch + XHR)
safari_network_detailsGet captured requests with headers/timing
safari_clear_networkClear captured requests
safari_mock_routeMock network responses (intercept fetch/XHR)
safari_clear_mocksRemove all network mocks

Console (4)

ToolDescription
safari_start_consoleStart capturing console messages
safari_get_consoleGet all captured messages
safari_clear_consoleClear captured messages
safari_console_filterFilter by level (log/warn/error)

Performance (2)

ToolDescription
safari_performance_metricsNavigation timing, Web Vitals, memory
safari_throttle_networkSimulate slow-3g/fast-3g/4g/offline

Data Extraction (4)

ToolDescription
safari_extract_tablesTables as structured JSON
safari_extract_metaAll meta: OG, Twitter, JSON-LD, canonical
safari_extract_imagesImages with dimensions and loading info
safari_extract_linksLinks with rel, external/nofollow detection

Advanced (5)

ToolDescription
safari_override_geolocationOverride browser geolocation
safari_list_indexed_dbsList IndexedDB databases
safari_get_indexed_dbRead IndexedDB records
safari_css_coverageFind unused CSS rules
safari_analyze_pageFull page analysis in one call

Automation (1)

ToolDescription
safari_run_scriptRun multiple actions in a single call (batch)

Security

Safari MCP runs locally on your Mac with minimal attack surface:

AspectDetail
NetworkNo remote connections โ€” all communication is local (stdio + localhost)
PermissionsmacOS system permissions required (Screen Recording for screenshots)
DataNo telemetry, no analytics, no data sent anywhere
ExtensionCommunicates only with localhost:9224, validated by Safari
CodeFully open source (MIT) โ€” audit every line

Safari MCP vs Alternatives

FeatureSafari MCPChrome DevTools MCPPlaywright MCP
CPU/Heat๐ŸŸข Minimal๐Ÿ”ด High๐ŸŸก Medium
Your loginsโœ… Yesโœ… YesโŒ No
macOS nativeโœ… WebKitโŒ ChromiumโŒ Chromium/WebKit
Browser dependenciesNoneChrome + debug portPlaywright runtime
Tools80~30~25
File uploadJS (no dialog)CDPPlaywright API
Image pasteJS (no clipboard)CDPPlaywright API
Focus stealโŒ BackgroundโŒ BackgroundโŒ Headless
Network mockingโœ…โŒโœ…
LighthouseโŒโœ…โŒ
Performance traceโŒโœ…โŒ

Tip: Use Safari MCP for daily browsing tasks (95% of work) and Chrome DevTools MCP only for Lighthouse/Performance audits.

Why Safari MCP and Not the Other Safari MCP Projects?

There are several "safari-mcp" projects floating around. Here's how they compare:

Feature๐Ÿฆ safari-mcp (this repo)lxman/safari-mcp-serverEpistates/MCPSafariHayoDev/safari-devtools-mcp
Tools80~1023~15
Installnpx safari-mcpManualBinarynpx
EngineDual (Extension + AppleScript)WebDriverExtension onlyDevTools Protocol
Keeps your real Safari loginsโœ… Yesโš ๏ธ Limitedโœ… YesโŒ Debug session
Background (no focus steal)โœ… YesโŒ Noโš ๏ธ Sometimesโœ… Yes
Storage tools (cookies, localStorage, IndexedDB)10002
Data extraction (tables, meta, images, links)4000
Network mockingโœ… YesโŒ NoโŒ NoโŒ No
Device emulation (iPhone, iPad, Pixel)โœ… YesโŒ NoโŒ NoโŒ No
File upload (no dialog)โœ… JS DataTransferโŒ NoโŒ NoโŒ No
Image paste (no clipboard touch)โœ… YesโŒ NoโŒ NoโŒ No
PDF exportโœ… YesโŒ NoโŒ NoโŒ No
Console capture4 tools011
Performance metrics + Web Vitalsโœ… YesโŒ NoโŒ Noโš ๏ธ Partial
Active maintenanceโœ… Multiple releases/week๐ŸŸก Sporadic๐ŸŸก Slow๐ŸŸก Slow
LicenseMITMITNone specifiedMIT
In MCP Registryโœ…โŒโŒโœ…
In Awesome MCPโœ…โŒโŒโŒ

TL;DR โ€” if you want the most complete Safari MCP with the smoothest install, the most tools, and active maintenance, this is the one.


Architecture

Safari MCP uses a dual-engine architecture โ€” the Extension is preferred for speed and advanced capabilities, with AppleScript as an always-available fallback:

Claude/Cursor/AI Agent
        โ†“ MCP Protocol (stdio)
   Safari MCP Server (Node.js)
        โ†“                    โ†“
   Extension (HTTP)     AppleScript + Swift daemon
   (~5-20ms/cmd)        (~5ms/cmd, always available)
        โ†“                    โ†“
   Content Script       do JavaScript in tab N
        โ†“                    โ†“
   Page DOM โ†โ†โ†โ†โ†โ†โ†โ†โ†โ† Page DOM

Key design decisions:

  • Dual engine with automatic fallback โ€” Extension is preferred; if not connected, AppleScript handles everything seamlessly
  • Persistent Swift helper โ€” one long-running process instead of spawning per command (16x faster)
  • Tab-indexed operations โ€” all JS runs on a specific tab by index, never steals visual focus
  • JS-first approach โ€” typing, clicking, file upload all use JavaScript events (no System Events keyboard conflicts)
  • No activate โ€” Safari is never brought to foreground

Safari Extension (Optional)

The Safari MCP Extension is optional but recommended. Without it, ~80% of functionality works via AppleScript alone. The extension adds capabilities that AppleScript cannot provide:

What the Extension Adds

CapabilityWith ExtensionAppleScript Only
Closed Shadow DOM (Reddit, Web Components)โœ… Full accessโŒ Invisible
Strict CSP sitesโœ… Bypasses via MAIN worldโŒ Often blocked
React/Vue/Angular state manipulationโœ… Deep (Fiber, ProseMirror)โš ๏ธ Basic
Loading state detection (spinners, skeletons)โœ… Smart detectionโŒ No
Dialog handling (alert/confirm)โŒโœ… Only AppleScript
Native OS-level click (CGEvent)โŒโœ… Only AppleScript
PDF exportโŒโœ… Only AppleScript

When do you need the extension? If you're automating modern SPAs with closed shadow DOM (e.g., Reddit), sites with strict Content Security Policy, or framework-heavy editors (Draft.js, ProseMirror, Slate).

Installing the Extension

The extension requires a one-time build with Xcode (free, included with macOS).

Note for npm users: The xcode/ directory is not included in the npm package. Clone the GitHub repository to build from source.

Prerequisites: Xcode (install from App Store โ€” free)

# 1. Clone the repo (the npm package does not include the Xcode project)
git clone https://github.com/achiya-automation/safari-mcp.git
cd safari-mcp

# 2. Build the extension
xcodebuild -project "xcode/Safari MCP/Safari MCP.xcodeproj" \
  -scheme "Safari MCP (macOS)" -configuration Release build

# 3. Ad-hoc sign the built app so Safari will load it
# (xcodebuild without a signing identity produces a bundle Safari silently rejects)
APP_PATH=$(find ~/Library/Developer/Xcode/DerivedData/Safari_MCP-*/Build/Products/Release -name "Safari MCP.app" -maxdepth 2 | head -1)
codesign --sign - --force --deep "$APP_PATH"

# 4. Re-sign safari-helper with the Apple Events entitlement
# (helps macOS surface the TCC Automation prompt reliably)
codesign --sign - --force --entitlements safari-helper.entitlements safari-helper

# 4. Open the app (needed once so Safari registers the extension)
open "$APP_PATH"

Alternatively, open xcode/Safari MCP/Safari MCP.xcodeproj directly in Xcode, select your Apple ID under Signing & Capabilities, and click Run. A free personal Apple Developer account is sufficient for local use.

Then in Safari:

  1. Safari โ†’ Settings โ†’ Advanced โ†’ enable Show features for web developers
  2. Safari โ†’ Develop โ†’ Allow Unsigned Extensions (required each Safari restart)
  3. Safari โ†’ Settings โ†’ Extensions โ†’ enable Safari MCP Bridge

The extension connects automatically to the MCP server on port 9224.

Note: "Allow Unsigned Extensions" resets every time Safari restarts. You'll need to re-enable it in the Develop menu after each restart. The extension itself stays installed.

Toolbar icon status:

  • ON โ€” connected to MCP server
  • OFF โ€” manually disabled via popup
  • (no badge) โ€” server not running, will auto-reconnect

macOS Permissions

Safari MCP needs these one-time permissions:

PermissionWhereWhy
JavaScript from Apple EventsSafari โ†’ Develop menuRequired for do JavaScript
Automation โ†’ SafariSystem Settings โ†’ Privacy & Security โ†’ AutomationRequired for all AppleScript-backed tools
Screen RecordingSystem Settings โ†’ Privacy & Security โ†’ Screen RecordingRequired for safari_screenshot
Accessibility (safari-helper)System Settings โ†’ Privacy & Security โ†’ AccessibilityRequired for safari_native_click, safari_native_keyboard, safari_native_hover and safari_save_pdf

Granting Accessibility to safari-helper (required for safari_native_*)

The safari_native_click, safari_native_keyboard and safari_native_hover tools inject OS-level CGEvent events into Safari without stealing focus. macOS requires the underlying helper binary to be approved in Accessibility before those events can reach a non-frontmost window.

  1. Open System Settings โ†’ Privacy & Security โ†’ Accessibility.
  2. Click + (unlock with your password if needed).
  3. Navigate to the helper binary and add it:
    • npm global install: $(npm root -g)/safari-mcp/safari-helper
    • npx / project install: ./node_modules/safari-mcp/safari-helper
    • From source clone: /path/to/safari-mcp/safari-helper
  4. Make sure the toggle next to it is ON.

The postinstall script re-signs the helper with a stable identifier (com.achiya-automation.safari-mcp) so this permission survives future upgrades โ€” without that step, every npm update would silently revoke approval because the binary's adhoc-signed identifier changes per build.

If safari_native_click reports success but the page doesn't react (no isTrusted: true click events fire), the helper is most likely missing this approval. The safari_* (non-native_) tools don't need it.

Granting Automation โ†’ Safari (important for IDE users)

macOS TCC grants Automation permission to the parent process that spawns the MCP server, not to safari-mcp itself. So you need to grant Automation โ†’ Safari to the app that runs Claude Code / Cursor / Windsurf โ€” typically Visual Studio Code or Terminal.

If the permission dialog never appears automatically, run this command once from a Terminal that already has Automation permission:

osascript -e 'tell application "Safari" to get URL of current tab of window 1'

That call registers the Terminal app in the Automation database and then triggers the prompt for Safari. After you approve it, subsequent MCP calls from any child process chain will work.


Troubleshooting

IssueFix
"AppleScript error"Enable "Allow JavaScript from Apple Events" in Safari โ†’ Develop
"Not authorized to send Apple events to Safari"Grant Automation โ†’ Safari to your IDE (see above)
"Not authorized" after npm updateUpdating changes the binary's cdhash โ€” macOS silently revokes Automation permission. Re-run the osascript one-liner above to re-grant it
safari_native_click reports success but page doesn't reactAdd safari-helper to System Settings โ†’ Privacy & Security โ†’ Accessibility (see Granting Accessibility above). Confirm by attaching a click listener with {capture:true} in the page console โ€” without the grant, no isTrusted: true event fires
Screenshots emptyGrant Screen Recording permission to Terminal/VS Code
Tab not foundCall safari_list_tabs to refresh tab indices
Hebrew keyboard issuesAll typing uses JS events โ€” immune to keyboard layout
HTTPS blockedsafari_navigate auto-tries HTTPS first, falls back to HTTP
Safari steals focusEnsure you're on latest version โ€” newTab restores your active tab

Works With

Safari MCP works with any MCP-compatible client:

ClientStatus
Claude Codeโœ… Tested daily
Claude Desktopโœ… Tested
Cursorโœ… Tested
Windsurfโœ… Compatible
VS Code + Continueโœ… Compatible

Contributing

PRs welcome! See CONTRIBUTING.md for setup instructions.

The codebase is two files:

  • safari.js โ€” Safari automation layer (AppleScript + JavaScript)
  • index.js โ€” MCP server with tool definitions

Sponsors

Safari MCP is free and open source. If it saves you time or CPU cycles, consider supporting its development:

Sponsor via PayPal

Your support funds:

  • ๐Ÿงช Testing across macOS versions and Safari releases
  • ๐Ÿ› ๏ธ New tools and features
  • ๐Ÿ“– Documentation and examples

Become the first sponsor!


Commercial Support

Need Safari MCP integrated into your product or agent stack? Achiya Automation offers:

  • Priority bug fixes and custom tool development for your use case
  • Integration consulting โ€” wiring Safari MCP into production agent systems (Claude, Cursor, n8n, custom)
  • Private deployment support โ€” multi-user Safari MCP, non-standard macOS environments, CI/CD
  • Training workshops for engineering teams adopting MCP-based automation

Built by the author of Safari MCP. Start a conversation โ†’


What agents unlock with Safari MCP

When an AI agent drives Safari MCP, it gets things a headless browser can't:

  • Real authenticated sessions โ€” Gmail, GitHub, Ahrefs, Slack, banking dashboards are all already logged in
  • Framework-aware form filling โ€” safari_fill_and_submit calls React/Vue/Angular setters natively, no guessing whether input events fired
  • Background operation โ€” the agent works in parallel while you keep using your Mac
  • One MCP call per workflow โ€” safari_run_script batches navigation + clicks + extraction into a single roundtrip

The pattern holds across models: drive the browser the human already trusts โ€” you inherit logins, cookies, extensions, and the user's exact environment in one step.


Community

6,000+ monthly npm downloads โ€” developers are building AI agents on macOS with Safari MCP.

  • GitHub Discussions โ€” ask questions, share use cases
  • Issues โ€” bug reports and feature requests
  • Good First Issues โ€” start contributing

Ecosystem

Other macOS MCP servers that complement Safari MCP:

ProjectWhat it doesWhen to use
mcp-server-macos-useOS-level macOS automation (accessibility, screen control)System-wide interactions beyond Safari
chrome-devtools-mcpChrome DevTools ProtocolLighthouse audits, Chrome-specific performance traces

Using Safari MCP alongside Chrome DevTools MCP? Safari handles 95% of daily browsing (zero overhead), Chrome handles the 5% that needs Lighthouse or Chrome-specific traces.


Like it? Give it a โญ

If Safari MCP saves you from Chrome overhead, a star helps others discover it:

Star this repo

Share on Twitter/X ยท Share on LinkedIn ยท Write about it

Star History Chart


Listed On

Glama MCP Registry MCP Scoreboard CI


License

MIT โ€” use it however you want.

Related Servers

NotebookLM Web Importer

Import web pages and YouTube videos to NotebookLM with one click. Trusted by 200,000+ users.

Install Chrome Extension