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.1.0.tar.gz (144.3 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.1.0-py3-none-any.whl (22.2 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for fx_audit_mcp-1.1.0.tar.gz
Algorithm Hash digest
SHA256 9e21ae1038431c255592007c72903725c4a18653f4c53de8ed0573812992bad3
MD5 0c76d12fb8417bbcecb8cd5913dced2f
BLAKE2b-256 6d88dcae001123eafbcccfc24950b268bf49161f3d822040bd112235cab16172

See more details on using hashes here.

Provenance

The following attestation bundles were made for fx_audit_mcp-1.1.0.tar.gz:

Publisher: ci.yml on MozillaSecurity/fx-audit-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 fx_audit_mcp-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: fx_audit_mcp-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 22.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for fx_audit_mcp-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 02b36c57c89a06114b0e6b43e741f46a716f406d5d7663209b8e2c4488d25a37
MD5 6a44cc4164435c2f6e2dac08eda61e7b
BLAKE2b-256 ca5bde9eca3a0fdba3e64214f4b28e0726d31e7afcf9634f8a84c3ae4dc8a6d9

See more details on using hashes here.

Provenance

The following attestation bundles were made for fx_audit_mcp-1.1.0-py3-none-any.whl:

Publisher: ci.yml on MozillaSecurity/fx-audit-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