Important
This is bbscope v2!
Major changes include a new command structure and powerful new features.
Breaking Change: Subcommands have changed!
- Old:
bbscope h1 - New:
bbscope poll h1(and similarly forbc,it,ywh, etc.)
New Features in v2:
- PostgreSQL Support (Optional): Store targets in a DB for persistence and querying.
- Changes Monitoring: Track new and removed targets over time (requires DB).
- AI Scope Normalization: Use LLMs to clean up messy scope strings.
- Docker Image: Ready-to-use image on GHCR.
- Centralized Polling: Poll multiple platforms in one go.
bbscope is a powerful scope aggregation tool for bug bounty hunters, designed to fetch, store, and manage program scopes from HackerOne, Bugcrowd, Intigriti, YesWeHack, and Immunefi right from your command line.
Visit bbscope.com to explore an hourly-updated list of public scopes from all supported platforms, stats, and more!
- Multi-Platform Support: Aggregates scopes from all major bug bounty platforms.
- PostgreSQL Database: Stores all scope data in a PostgreSQL database for reliable, concurrent access.
- Powerful Querying: Easily print targets by type (URLs, wildcards, mobile, etc.), platform, or program.
- Track Changes: Monitor scope additions and removals over time.
- LLM Cleanup (opt-in): Let GPT-style models fix messy scope strings in bulk when polling.
- Flexible Output: Get your data in plain text, JSON, or CSV.
Ensure you have a recent version of Go installed, then run:
go install github.com/sw33tLie/bbscope/v2@latestYou can also run bbscope using Docker. The Docker image is automatically built and published to GitHub Container Registry (GHCR) on every push.
Pull the latest image:
docker pull ghcr.io/sw33tlie/bbscope:latestRun bbscope with Docker:
docker run --rm ghcr.io/sw33tlie/bbscope:latest [command] [flags]Tip: Add --pull=always to the command if you want to automatically always use the latest bbscope version.
Important: To persist your configuration across container runs, bind-mount the config file:
# Run with config mounted
docker run --rm \
-v ~/.bbscope.yaml:/root/.bbscope.yaml \
ghcr.io/sw33tlie/bbscope:latest poll --db -b -pNote: The container connects to your PostgreSQL database using the db_url configured in ~/.bbscope.yaml. Make sure your database is accessible from the container (use host.docker.internal for local databases on macOS/Windows, or your database's network address).
bbscope requires API credentials for private programs and a PostgreSQL connection URL. After running the tool for the first time, it will create a configuration file at ~/.bbscope.yaml.
You'll need to fill in your credentials and database URL:
# PostgreSQL connection URL
db_url: "postgres://user:password@localhost:5432/bbscope?sslmode=disable"
hackerone:
username: "" # HackerOne username
token: "" # https://docs.hackerone.com/en/articles/8410331-api-token
bugcrowd:
email: ""
password: ""
otpsecret: "" # Your 2FA secret key string
intigriti:
token: "" # https://app.intigriti.com/researcher/personal-access-tokens
yeswehack:
email: ""
password: ""
otpsecret: "" # Your 2FA secret key string
ai:
provider: "openai"
api_key: "" # or set OPENAI_API_KEY env var
model: "gpt-4o-mini"
max_batch: 25
max_concurrency: 10Alternatively, you can provide credentials directly via command-line flags when running a poll subcommand. Flags will always override values in the configuration file.
Authentication Flags for poll Subcommands:
| Command | Flag | Description |
|---|---|---|
poll h1 |
--user, --token |
Your HackerOne username and API token. |
poll bc |
--token |
A live _crowdcontrol_session_key cookie. Use as an alternative to email/pass/otp. |
--email, --password, --otp-secret |
Your Bugcrowd login credentials. | |
poll it |
--token |
Your Intigriti authorization token (Bearer). |
poll ywh |
--token |
A live YesWeHack bearer token. Use as an alternative to email/pass/otp. |
--email, --password, --otp-secret |
Your YesWeHack login credentials. |
Database Configuration (Optional):
To use bbscope's database features (like tracking changes or querying targets), you need a PostgreSQL database.
Option 1: Use an existing PostgreSQL instance
Add your connection string to ~/.bbscope.yaml:
db_url: "postgres://user:password@localhost:5432/bbscope?sslmode=disable"Option 2: Quick setup with Docker
Important
Replace <YOUR_SECURE_PASSWORD> with a strong, unique password.
docker run --name bbscope-db \
-e POSTGRES_USER=bbscope \
-e POSTGRES_PASSWORD=<YOUR_SECURE_PASSWORD> \
-e POSTGRES_DB=bbscope \
-p 5432:5432 \
-d postgres:alpineThen add to your ~/.bbscope.yaml:
db_url: "postgres://bbscope:<YOUR_SECURE_PASSWORD>@localhost:5432/bbscope?sslmode=disable"Tables are automatically created on the first run.
bbscope is organized into two main commands: poll and db.
The poll command fetches scope data from the platforms. You can poll all platforms at once or specify which ones to poll.
Subcommands:
bbscope poll: Polls all configured platforms.bbscope poll h1: Polls HackerOne.bbscope poll bc: Polls Bugcrowd.bbscope poll it: Polls Intigriti.bbscope poll ywh: Polls YesWeHack.bbscope poll immunefi: Polls Immunefi (no authentication required).
Flags for poll:
| Flag | Description | Default |
|---|---|---|
--db |
Save results to the database and print changes. | false |
--ai |
Normalize messy targets in bulk using an LLM before writing to the DB (requires API key). | false |
-b, --bbp-only |
Only fetch programs offering monetary rewards. | false |
-p, --private-only |
Only fetch data from private programs. | false |
--category |
Scope categories to include (e.g., url, cidr, mobile). |
"all" |
-o, --output |
Output flags for printing to stdout (t=target, d=description, c=category, u=program URL). |
"tu" |
-d, --delimiter |
Delimiter for txt output when using multiple output flags. |
" " |
--oos |
Include out-of-scope targets in the output. | false |
--concurrency |
Number of concurrent fetches per platform. | 5 |
Messy scope entries from platforms can now be cleaned up in bulk with the --ai flag:
bbscope poll --db --ai- Requires an API key in
~/.bbscope.yamlunder theaisection (or theOPENAI_API_KEYenvironment variable). - Entries are batched per program to minimize API calls.
- If the model fails or omits an entry, the original target is used so nothing is lost.
- When the text explicitly says "out of scope" or similar, the AI pass can flip the entry's
in_scopeflag for you. - Tune throughput with
max_batch(targets per request) andmax_concurrency(simultaneous requests) in theaiconfig section.
The db command lets you query and manage the data stored in your PostgreSQL database.
Prints scope data from the database.
Usage: bbscope db print [type]
type(optional): Filter by target type. Can beurls,wildcards,apis, ormobile. If omitted, prints all types.
Flags for db print:
| Flag | Description | Default |
|---|---|---|
--platform |
Comma-separated platforms to filter by (e.g., h1,bc), or all. |
"all" |
--program |
Filter by a specific program handle or URL. | |
--format |
Output format: txt, json, or csv. |
"txt" |
-o, --output |
Output flags for txt format (t=target, d=description, c=category, u=program URL). |
"tu" |
-d, --delimiter |
Delimiter for txt output. |
" " |
--oos |
Include out-of-scope targets. | false |
--since |
Show targets added since a given RFC3339 timestamp (e.g., 2023-10-27T10:00:00Z). |
Shows high-level statistics about the data in the database.
Usage: bbscope db stats
Shows the most recent scope changes (additions/removals).
Usage: bbscope db changes
| --limit | Number of recent changes to show. | 50 |
Search for a string in current and historical scopes.
Usage: bbscope db find [query]
Open a psql shell connected to your database.
Usage: bbscope db shell
The bbscope DB schema will also be printed to stdout for ease of reference.
Add a custom target to the database manually.
Usage: bbscope db add --target <target> [flags]
Flags for db add:
| Flag | Description | Default |
|---|---|---|
-t, --target |
Target to add (can be comma-separated). | |
-c, --category |
Category of the target (e.g., wildcard, url). |
"wildcard" |
-u, --program-url |
Program URL to associate with the target. | "custom" |
1. First-Time Setup: Poll all private, bounty-only programs and save to DB
This is a great first command to run to populate your database.
bbscope poll --db -b -p2. Print all wildcard targets from HackerOne and Bugcrowd
bbscope db print wildcards --platform h1,bc3. Get all targets for a specific program in JSON format
bbscope db print --program "hackerone" --format json4. Show the 10 most recent scope changes
bbscope db changes --limit 105. Get a unique list of program URLs from Intigriti that have bounties
bbscope db print --platform it --output u | sort -u