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.24.0.tar.gz (33.6 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.24.0-py3-none-any.whl (29.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: maestro_browser_bridge-1.24.0.tar.gz
  • Upload date:
  • Size: 33.6 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.24.0.tar.gz
Algorithm Hash digest
SHA256 1b1f675336e63aa4e1b318b5c19793e8a1b5745ad22a0c8363bc496fedd8ea4c
MD5 ba96a1a680d3e2d0c23acf8826aeb810
BLAKE2b-256 0485d0d3b1f002789146c2172f47ae5249e14ae3f7519191e90cdfe2a28dd7b8

See more details on using hashes here.

Provenance

The following attestation bundles were made for maestro_browser_bridge-1.24.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.24.0-py3-none-any.whl.

File metadata

File hashes

Hashes for maestro_browser_bridge-1.24.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3fddd3cae44bc91bd9c8adbf0fef487d6f15dcdc9d56b3c733d9be20bd09a5c3
MD5 ddaff37a53be58a9e78468189b00f74d
BLAKE2b-256 6fb5255955dbdc621c4b4f319cf3044aa30e0c0564773968eb46a1db62ff9cfe

See more details on using hashes here.

Provenance

The following attestation bundles were made for maestro_browser_bridge-1.24.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