mcp-firefox
Connects to Firefox's Remote Debugging Protocol over TCP, exposing browser DevTools capabilities (JS evaluation, navigation, screenshots, network capture) as tools for LLMs via MCP.
README
mcp-firefox
An MCP (Model Context Protocol) server that connects to Firefox's Remote Debugging Protocol (RDP) over TCP, exposing browser DevTools capabilities as tools for LLMs.
How It Works
Firefox has a built-in Remote Debugging Protocol that speaks length-prefixed JSON over TCP. This server maintains a persistent connection to that port and translates MCP tool calls into RDP messages, returning the results to the LLM.
LLM ↔ MCP (HTTP :8090) ↔ Firefox RDP (TCP :6000)
The RDP client uses a background reader task to handle both request/response pairs and unsolicited events (like network traffic), enabling real-time capture features.
Tools
| Tool | Description |
|---|---|
evaluate_js |
Evaluate a JavaScript expression in the current tab's console (supports top-level await) |
list_tabs |
List all open browser tabs with URLs and titles |
navigate |
Navigate the current tab to a URL |
get_page_source |
Get the full HTML source of the current page |
get_console_messages |
Get cached console messages (errors, logs) |
read_page |
Extract readable text content from the page (strips nav, ads, boilerplate) |
screenshot |
Take a screenshot — viewport, full page, or a specific CSS selector element |
start_capture |
Start capturing network requests (like opening the Network tab) |
read_capture |
Read captured network events (URLs, methods, status, timing, optionally bodies) |
stop_capture |
Stop network capture and clean up |
raw_rdp_command |
Send arbitrary RDP JSON for experimentation |
Firefox Setup
1. Enable Remote Debugging
Open about:config in Firefox and set:
| Preference | Value | Purpose |
|---|---|---|
devtools.debugger.remote-enabled |
true |
Allow remote debug connections |
devtools.debugger.prompt-connection |
false |
Skip the "allow connection?" dialog (optional) |
devtools.chrome.enabled |
true |
Enable chrome debugging |
2. Start the Debug Listener
firefox --start-debugger-server 6000
This opens a TCP listener on localhost:6000. Your tabs and session restore normally.
3. Verify
ss -tlnp | grep 6000
You should see Firefox listening on 127.0.0.1:6000.
Installation
Requires Python 3.11+. Uses uv for dependency management:
uv venv
uv pip install -e .
Running
.venv/bin/firefox-mcp
The MCP server starts on http://0.0.0.0:8090/mcp using streamable HTTP transport (stateless mode).
Environment Variables
| Variable | Default | Description |
|---|---|---|
FIREFOX_RDP_HOST |
localhost |
Firefox RDP host |
FIREFOX_RDP_PORT |
6000 |
Firefox RDP port |
MCP Client Configuration
{
"mcpServers": {
"firefox-devtools": {
"url": "http://localhost:8090/mcp"
}
}
}
Usage Examples
Page Content & Screenshots
# Read article text from a news site you're logged into
> read_page
# Take a screenshot of a specific element
> screenshot(selector=".article-body")
# Full page screenshot
> screenshot(fullpage=True)
Network Capture
Capture API traffic from web apps (streaming services, SPAs, etc.):
# Start recording network traffic
> start_capture
# Navigate to the app or trigger actions
> navigate("https://www.disneyplus.com/home")
# See what API calls were made
> read_capture
# Get response bodies (JSON payloads, manifests, etc.)
> read_capture(include_bodies=True)
# Done
> stop_capture
Raw RDP Exploration
> raw_rdp_command({"to": "root", "type": "listTabs"})
> raw_rdp_command({"to": "<consoleActor>", "type": "getCachedMessages", "messageTypes": ["PageError", "ConsoleAPI"]})
Use list_tabs first to discover actor IDs, then experiment with raw_rdp_command.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.