h1-brain
Allows AI agents to search, analyze, and build on past bug bounty work, including personal reports, program scopes, and public disclosed reports from HackerOne.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@h1-brainBrief me on Shopify program scope, my past reports, and public disclosures"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
h1-brain
An MCP server that connects your AI assistant to HackerOne. It pulls your bug bounty history, program scopes, and report details into a local SQLite database, then exposes tools that let any MCP-compatible client (Claude Desktop, Claude Code, etc.) search, analyze, and build on your past work.
It also ships with a pre-built database of 3,600+ publicly disclosed bounty-awarded reports from the HackerOne community — full vulnerability write-ups, weakness types, and bounty amounts. The AI uses both your personal data and public knowledge to generate attack briefings.
The primary tool, hack(handle), generates a full hacking session briefing in a single call: fresh scope from the API, your past findings, public disclosures for that program, weakness patterns, untouched assets, and suggested attack vectors — all formatted as actionable instructions that put the AI in offensive mode.

How It Works
For a full walkthrough, check out the three-part Bug Bounty Goldfish series:
Teaching Claude Everything You've Hacked — Why I built h1-brain and how to set it up
What h1-brain Actually Does — Every tool explained, from search to the
hack()briefingRunning h1-brain Against a Real Target — A start-to-finish walkthrough on an actual program
graph LR
A["Claude Desktop / Code"] -->|MCP Protocol| B["h1-brain server"]
B -->|API calls| C["HackerOne API"]
B -->|reads / writes| D["Your Reports DB"]
B -->|reads| E["Public Reports DB"]
C -->|reports, programs, scopes| B
D -->|your history + analysis| A
E -->|community knowledge| A
style A fill:#ff5c5c,stroke:#ff5c5c,color:#fff
style B fill:#1a1d27,stroke:#ff5c5c,color:#fff
style C fill:#1a1d27,stroke:#555,color:#fff
style D fill:#1a1d27,stroke:#555,color:#fff
style E fill:#1a1d27,stroke:#555,color:#fffflowchart TD
A["hack(handle)"] --> B["Fetch fresh scope from HackerOne API"]
B --> C["Pull your reports on this program from SQLite"]
C --> D["Analyze weakness patterns across ALL programs"]
D --> E["Identify untouched bounty-eligible assets"]
E --> F["Cross-reference public disclosed reports for this program"]
F --> G["Generate attack briefing with agent instructions"]
style A fill:#ff5c5c,stroke:#ff5c5c,color:#fff
style G fill:#ff5c5c,stroke:#ff5c5c,color:#fff
style B fill:#1a1d27,stroke:#555,color:#fff
style C fill:#1a1d27,stroke:#555,color:#fff
style D fill:#1a1d27,stroke:#555,color:#fff
style E fill:#1a1d27,stroke:#555,color:#fff
style F fill:#1a1d27,stroke:#555,color:#fffRelated MCP server: HackerOne MCP Server
Requirements
Python 3.10+
A HackerOne API token (generate one here)
Setup
Install and register with Codex from GitHub:
curl -fsSL https://raw.githubusercontent.com/imattas/HackerOne-Brain/main/install.sh | bashInstall with HackerOne credentials already configured for the MCP server:
curl -fsSL https://raw.githubusercontent.com/imattas/HackerOne-Brain/main/install.sh \
| H1_USERNAME=your_hackerone_username H1_API_TOKEN=your_api_token bashOther install options:
curl -fsSL https://raw.githubusercontent.com/imattas/HackerOne-Brain/main/install.sh | AGENT=claude bash
curl -fsSL https://raw.githubusercontent.com/imattas/HackerOne-Brain/main/install.sh | AGENT=none H1_BRAIN_INSTALL_DIR="$HOME/tools/h1-brain" bashManual install:
git clone https://github.com/imattas/HackerOne-Brain.git
cd HackerOne-Brain
python -m venv venv
source venv/bin/activate
pip install -r requirements.txtThe public disclosed reports database (disclosed_reports.db) is downloaded by
the installer. It is not committed to this mirror because disclosed reports can
contain historical secret-looking strings that GitHub push protection blocks.
For manual installs, run ./scripts/fetch-disclosed-db.sh.
For a Codex local install from this checkout:
./scripts/install-agent.sh codexAgent Compatibility
h1-brain is a stdio MCP server and works with any local MCP-compatible agent that can launch a command, including Codex, Claude Code, Claude Desktop, Cursor, Windsurf, Cline, and similar clients.
The server starts even when HackerOne credentials are not configured, which lets
agents enumerate tools during startup. Tools that call the HackerOne API return
a setup message until H1_USERNAME and H1_API_TOKEN are available. Public
disclosed-report search does not need HackerOne credentials.
If your clone did not hydrate the Git LFS database, fetch it directly:
./scripts/fetch-disclosed-db.shSee docs/multi-agent-setup.md for agent-specific configuration examples.
Connecting to Agents
Codex
codex mcp add h1-brain \
--env H1_USERNAME=your_hackerone_username \
--env H1_API_TOKEN=your_api_token \
-- /path/to/h1-brain/venv/bin/python /path/to/h1-brain/server.pyOr without credentials, so Codex can start and expose public-report tools:
codex mcp add h1-brain -- /path/to/h1-brain/venv/bin/python /path/to/h1-brain/server.pyClaude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"h1-brain": {
"command": "/path/to/h1-brain/venv/bin/python",
"args": ["/path/to/h1-brain/server.py"],
"env": {
"H1_USERNAME": "your_hackerone_username",
"H1_API_TOKEN": "your_api_token"
}
}
}
}Restart Claude Desktop after saving.
Claude Code
claude mcp add h1-brain \
-e H1_USERNAME=your_hackerone_username \
-e H1_API_TOKEN=your_api_token \
-- /path/to/h1-brain/venv/bin/python /path/to/h1-brain/server.pyFirst Run
After connecting, populate your personal database:
fetch_rewarded_reports— Pulls all your bounty-awarded reports with full vulnerability write-ups. This is the most important step.fetch_programs— Pulls all programs you have access to.
These only need to be run once. Re-run periodically to sync new reports.
The public disclosed reports are ready to query immediately — no setup needed.
Tools
hack(handle)
The primary entry point. One call does everything:
Fetches fresh program scopes from the HackerOne API
Pulls your past rewarded reports for that program
Cross-references your full report history for weakness patterns
Identifies untouched bounty-eligible assets
Pulls public disclosed reports for this program — what other researchers found and got paid for
Suggests attack vectors based on weaknesses that paid elsewhere but haven't been found here
Returns an attack briefing that puts the AI in offensive mode
Briefing structure:
Scope — bounty-eligible and non-bounty assets with severity caps
Your Past Findings — rewarded reports with severity, weakness type, and bounty amounts
Weakness Types That Worked — what's been rewarded here before
Untouched Scope — bounty-eligible assets with zero findings from you
Suggested Attack Vectors — weaknesses rewarded on other programs but not yet found here
Public Disclosed Reports — what other researchers found on this program, weakness patterns from public disclosures
Instructions — puts the AI in attack mode with specific directives
Your Reports
These query your personal data (h1_data.db). No API calls, instant results.
Tool | Description |
| Search your rewarded reports by title, program, weakness type, or severity |
| Full report details with vulnerability write-up and attachments |
| Reports grouped by program with totals |
| Search your stored programs |
| Search in-scope assets across programs |
| Fresh download URLs for report attachments (expire in ~1 hour) |
Public Disclosed Reports
These query the pre-built database of 3,600+ bounty-awarded public disclosures (disclosed_reports.db).
Tool | Description |
| Full-text search across public reports — titles and vulnerability write-ups |
| Full details of a public disclosed report |
Data Sync
Tool | Description |
| Sync your bounty-awarded reports from the API |
| Sync your accessible programs |
| Sync scopes for a program (called automatically by |
Architecture
server.py MCP server
hack_instructions.md Attack briefing instructions (loaded by hack())
h1_data.db Your personal reports, programs, scopes (auto-created, gitignored)
disclosed_reports.db 3,600+ public disclosed bounty reports (ships with repo)
requirements.txt Python dependencies (mcp, httpx)Two Databases
Database | Contains | Source |
| Your personal reports, programs, scopes, attachments | HackerOne API (your account) |
| Public disclosed reports that paid a bounty | Pre-built, ships with repo |
The AI knows the difference. Your personal tools (search_reports, get_report) query your data. Public tools (search_disclosed_reports, get_disclosed_report) query community data. hack() uses both.
Public Reports Database
The disclosed_reports.db contains publicly disclosed HackerOne reports that:
Paid a bounty
Have actual vulnerability write-ups (redacted/empty reports are excluded)
Each report includes: title, vulnerability details, weakness type, program, asset, CVEs, and bounty amount (when available).
Author
Patrik Grobshäuser — LinkedIn · X
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/imattas/HackerOne-Brain'
If you have feedback or need assistance with the MCP directory API, please join our Discord server