Skip to main content

Firefox security audit MCP tools

Project description

fx-audit-mcp

MCP tools for Firefox security auditing. Provides async Python tools and a FastMCP server for running testcases in Firefox and SpiderMonkey, building Firefox and NSS with ASAN, and querying Bugzilla — all with structured Pydantic return types suitable for use with LLM agent frameworks.

Tools

Tool Description
browser_evaluator Run a testcase in ASAN Firefox via grizzly replay, detect crashes
package_testcase Bundle a testcase directory with prefs and env into a grizzly TestCase
js_shell_evaluator Run a JS testcase in the SpiderMonkey shell, detect crashes and sanitizer output
nss_gtest_evaluator Run an NSS GTest and report any ASan crash
build_firefox Build Firefox via mach build with a specified MOZCONFIG
build_nss Build NSS with ASAN via security/nss/build.sh
search_bugs Search Bugzilla using raw REST query parameters
get_bugs Fetch bugs by ID in bulk
get_bug_comments Fetch all comments for a single bug
get_bug_attachments Fetch attachments for a bug

Installation

pip install fx-audit-mcp

Requires Python 3.12+.

Usage

As Python functions

The execution tools (browser, JS shell, NSS gtest, Firefox/NSS build) are async functions with structured Pydantic return types. The Bugzilla tools are only available via the MCP server (see below).

import asyncio
from pathlib import Path
from fx_audit_mcp import browser_evaluator, js_shell_evaluator

async def main():
    result = await browser_evaluator(
        content="<script>crashMe()</script>",
        filename="test.html",
        firefox_binary=Path("/path/to/obj-firefox-asan/dist/bin/firefox"),
        timeout=30,
    )
    print(result.crashed, result.message)
    if result.logs:
        print(result.logs.crashdata[:500])

asyncio.run(main())

As an MCP server

fx-audit-mcp exposes all execution tools (browser, JS shell, NSS gtest, Firefox/NSS build) as an MCP server over stdio:

fx-audit-mcp

fx-audit-bugzilla-mcp exposes the Bugzilla query tools separately:

BUGZILLA_API_KEY=your_key fx-audit-bugzilla-mcp

Set BUGZILLA_URL to override the default Mozilla Bugzilla instance.

Claude Desktop / Claude Code .mcp.json example:

{
  "mcpServers": {
    "fx-audit": {
      "command": "fx-audit-mcp",
      "env": {
        "FIREFOX_SOURCE_ROOT": "/path/to/firefox",
        "FIREFOX_BINARY": "/path/to/firefox/obj-firefox-asan/dist/bin/firefox"
      }
    },
    "fx-audit-bugzilla": {
      "command": "fx-audit-bugzilla-mcp",
      "env": {
        "BUGZILLA_API_KEY": "your_key_here"
      }
    }
  }
}

With pydantic-ai

Tools integrate directly with pydantic-ai agents:

from pydantic_ai import Agent
from fx_audit_mcp import browser_evaluator, js_shell_evaluator

agent = Agent(
    "anthropic:claude-opus-4-7",
    tools=[browser_evaluator, js_shell_evaluator],
)

Environment Variables

Variable Used by Description
BUGZILLA_API_KEY fx-audit-bugzilla-mcp Required; your Bugzilla API key
BUGZILLA_URL fx-audit-bugzilla-mcp Bugzilla REST base URL (default: Mozilla's)
FIREFOX_SOURCE_ROOT fx-audit-build-firefox Default --firefox-dir for the CLI entry point

Crash Detection

  • browser_evaluator: Crash signatures in ignored_signatures/ (FuzzManager format) are filtered out before returning, so common shutdown hangs don't pollute results.
  • js_shell_evaluator: Detects crashes via negative exit code (signal) or AddressSanitizer/UndefinedBehaviorSanitizer in stderr. JS errors (positive exit codes) are not treated as crashes.
  • nss_gtest_evaluator: Detects AddressSanitizer in stdout or stderr.

Development

# Install with dev dependencies
uv sync --group dev

# Run tests
uv run pytest

# Lint and format
uv run ruff check --fix .
uv run ruff format .

# Type check
uv run mypy src/

# Install pre-commit hooks
uv run pre-commit install

License

Mozilla Public License 2.0

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

fx_audit_mcp-1.0.0.tar.gz (148.6 kB view details)

Uploaded Source

Built Distribution

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

fx_audit_mcp-1.0.0-py3-none-any.whl (25.7 kB view details)

Uploaded Python 3

File details

Details for the file fx_audit_mcp-1.0.0.tar.gz.

File metadata

  • Download URL: fx_audit_mcp-1.0.0.tar.gz
  • Upload date:
  • Size: 148.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for fx_audit_mcp-1.0.0.tar.gz
Algorithm Hash digest
SHA256 115830c1b2b8f22fb1d45259e12cfcb6f359fc2516abf18e86a873a591890b74
MD5 9661b43483c5d921bba8693beb7f580f
BLAKE2b-256 90e46d9ab6a32642398ff5a4cde76c6949927cfe96e69792695ba46cfa4b9858

See more details on using hashes here.

File details

Details for the file fx_audit_mcp-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: fx_audit_mcp-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 25.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for fx_audit_mcp-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 584469f60e8d6c2ffa2bbeee1988b9168a2333abaa7cc951b182f864276b9b80
MD5 e9a3bf7d6157ac06ff80aa012c333466
BLAKE2b-256 71b1cb8b07fd97299c17b7827fd10c9f10b601e02628177d9698e2c31ef0c747

See more details on using hashes here.

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