Skip to main content

Local browser bridge for Remote AI Maestro — runs a Playwright-managed Chromium and exposes BROWSER_* commands over WebSocket.

Project description

maestro-browser-bridge

Local browser bridge for Remote AI Maestro.

The bridge is the companion app you install on the same laptop where you keep your real browser. It launches a Playwright-managed Chromium in an isolated profile and exposes it over a WebSocket so an AI agent running inside a Maestro sandbox can drive it — navigate, click, type, screenshot, read DOM, capture console logs.

This is the Phase 2 counterpart to the simpler Phase 1 maestro browser open <url> command, which only pops URLs in your already-open browser via the frontend's window.open. The bridge gives Claude (or any agent) real browser control without ever touching your logged-in Chrome profile.

Why a separate process

The AI agent runs on a remote machine (or an EC2 sandbox) but the browser to be controlled lives on your local desktop. There is no other process that runs on the user's actual laptop in a known-good location — the agent daemon runs on whichever machine the sandbox is bound to, which may be EC2. So we ship a dedicated bridge process that runs on the user's laptop, maintains an outbound WebSocket to the relay, and translates BROWSER_* messages into Playwright calls.

The bridge is per-user (one bridge per laptop) — distinct from the agent daemon, which is per-machine. Relay routing maps user_id → bridge.

Install

pip install maestro-browser-bridge

# Pre-download the Playwright Chromium binary (~200MB)
playwright install chromium

# Configure once
maestro-browser-bridge configure \
  --relay-url wss://relay.thesavvydeveloper.com \
  --user-id YOUR_USER_UUID \
  --user-token YOUR_BRIDGE_TOKEN

# Start
maestro-browser-bridge start

--detach is wired but not yet implemented; for now run the bridge in the foreground (or wrap it in your own service manager — launchd / systemd unit shipping is planned).

Status

This package is the scaffold for the Phase 2 work tracked in _reference/11_BROWSER_CONTROL.md and implementation_plan.md's "BC — Browser Control (Phase 2)" section. The protocol models, dispatch shell, and CLI surface are in place; the actual Playwright handlers raise NotImplementedError and will be wired in subsequent commits (BC.1.2 in the plan).

Development

# Editable install with test deps (from the repo root)
pip install -e ./bridge[test]

# Run tests
cd bridge && pytest

# Smoke check the CLI
maestro-browser-bridge --version
maestro-browser-bridge --help

References

  • Architecture & wire protocol: _reference/11_BROWSER_CONTROL.md
  • Milestone plan: _reference/12_BROWSER_PHASE2_PLAN.md
  • Pip package contract: implementation_plan.md § BC.1

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

maestro_browser_bridge-1.26.0.tar.gz (36.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

maestro_browser_bridge-1.26.0-py3-none-any.whl (31.9 kB view details)

Uploaded Python 3

File details

Details for the file maestro_browser_bridge-1.26.0.tar.gz.

File metadata

  • Download URL: maestro_browser_bridge-1.26.0.tar.gz
  • Upload date:
  • Size: 36.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for maestro_browser_bridge-1.26.0.tar.gz
Algorithm Hash digest
SHA256 4f01c666fb77f1684a1e8a44e46e3473ca8708b2d700c35e682a47558ba02c38
MD5 d61a226ac9676575905cc92ade90f93f
BLAKE2b-256 6aa540c4ba1fc13f065cfd7764762863cb22762b85703934fe4218c6c8138aad

See more details on using hashes here.

Provenance

The following attestation bundles were made for maestro_browser_bridge-1.26.0.tar.gz:

Publisher: release.yml on shaunchew/remote-ai-maestro

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file maestro_browser_bridge-1.26.0-py3-none-any.whl.

File metadata

File hashes

Hashes for maestro_browser_bridge-1.26.0-py3-none-any.whl
Algorithm Hash digest
SHA256 97776bcff74404ae62b728f4935a1ed4629a5019ddb775e6a78d01b77a6076d9
MD5 224b9c9336412292ff37e325984ab059
BLAKE2b-256 880f1ab787e57a980504d7223fe776b883b6c9d8a81178b387952699cb0e1e06

See more details on using hashes here.

Provenance

The following attestation bundles were made for maestro_browser_bridge-1.26.0-py3-none-any.whl:

Publisher: release.yml on shaunchew/remote-ai-maestro

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page