Skip to main content

MCP server for browser-use

Project description

browser-mcp

A MCP (Model Control Protocol) server for browser-use library. This package allows AI agents to perform web browsing tasks through a standardized interface.

Installation

You can install the package using pip:

pip install browser-mcp

Or with uv (recommended):

uv pip install browser-mcp

Setup

For development, clone the repository and install in development mode:

# Clone the repository
git clone https://github.com/pranav7/browser-mcp.git
cd browser-mcp

# Install dependencies with uv
uv pip install -e .

# Or with pip
pip install -e .

Environment Variables

Create a .env file with your OpenAI API key:

OPENAI_API_KEY=your_api_key_here

Usage

Running the MCP Server

In Development Mode

When working with the package in development mode, you can run it directly with Python:

python -m src

In Production

After installing the package from PyPI, you can run it with uvx:

uvx browser-mcp

The package is specifically designed to work with uvx, which allows for more efficient package loading and execution.

Using as a Client

from mcp.client import Client

async def main():
    client = await Client.connect()

    # Perform a task with the browser
    result = await client.rpc("perform_task_with_browser",
                             task="Search for the latest news about AI and summarize the top 3 results")
    print(result)

    await client.close()

Programmatic Usage

You can also use the package programmatically:

# In development mode
from src import run

# In production (after installing the package)
# from browser_mcp import run

# Run the MCP server with stdio transport
run(transport="stdio")

# Or with SSE transport
# run(transport="sse")

Available RPC Methods

  • perform_task_with_browser(task: str) - Performs a specified task using the browser-use Agent with GPT-4o-mini

Development

Testing

Tests can be run with:

python -m unittest discover

You can also test the package functionality with:

python test_uvx.py

This script will:

  1. Test importing the package directly (development mode)
  2. Attempt to run it with uvx (production mode)

Note: The uvx test may fail in development mode unless the package is published to PyPI. This is expected behavior.

Publishing to PyPI

This project uses GitHub Actions to automatically publish to PyPI when a new release is created. The workflow:

  1. Builds the package using uv
  2. Publishes it to PyPI using trusted publishing

To create a new release:

  1. Update the version in pyproject.toml
  2. Create a new release on GitHub
  3. The GitHub Action will automatically build and publish the package

License

MIT License

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

browser_mcp-0.1.1.tar.gz (4.0 kB view details)

Uploaded Source

Built Distribution

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

browser_mcp-0.1.1-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file browser_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: browser_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 4.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for browser_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 831bc4687472e5000974cfa92fc75d97d218b6750db19eab03e99cb2edda53fd
MD5 0e5d5e109699c9932303372ecf62c16f
BLAKE2b-256 52da5216831553e9bebdb2c4d3ee0530bbb4e2cbdf3f19dd7351ff5e1b42a6be

See more details on using hashes here.

Provenance

The following attestation bundles were made for browser_mcp-0.1.1.tar.gz:

Publisher: python-publish.yml on pranav7/browser-mcp

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

File details

Details for the file browser_mcp-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: browser_mcp-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 4.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for browser_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4052500f5a32fdeb934f7cd2a2b954e1005e9d76944a994313ea32a35ea2b933
MD5 70d7f47e71b2937c1f357d209a457a52
BLAKE2b-256 ba317f9e4f02396abbfdce956818e020a2f798ae798bb6f367c22298c5d8d5b0

See more details on using hashes here.

Provenance

The following attestation bundles were made for browser_mcp-0.1.1-py3-none-any.whl:

Publisher: python-publish.yml on pranav7/browser-mcp

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