Skip to main content

A modern, modular OSINT CLI for private investigators.

Project description

osint-investigator

A modern, modular OSINT command-line tool for private-investigation work on macOS / Linux.

Built with Typer + Rich for a fast, pleasant terminal UX, Holehe for email-existence checks, and Playwright for JavaScript-heavy people-finder sites such as cyberbackgroundchecks.com.

CI License: MIT Python 3.10+


⚠️ Ethical and legal use

This tool is for authorised investigative work only. Examples of legitimate use:

  • Investigating your own accounts and digital footprint.
  • Licensed private-investigator casework with a signed engagement.
  • Due-diligence research on a counterparty in a transaction you're a party to.
  • Missing-persons work in cooperation with family or law enforcement.
  • Defensive security research on assets you own or are authorised to test.

You are personally responsible for complying with:

  • The Computer Fraud and Abuse Act (US) and equivalents in your country.
  • GDPR (EU/UK), CCPA (California), PIPEDA (Canada), and other privacy laws.
  • Each target site's Terms of Service.
  • Any PI licensing requirements in your jurisdiction.
  • Stalking, harassment, and anti-doxxing statutes — these apply even when the data is public.

Do not use this tool to: stalk, harass, dox, blackmail, surveil intimate partners, profile people on the basis of protected characteristics, or investigate anyone you don't have a lawful basis to investigate. If you're unsure whether your use is lawful, talk to a lawyer before running it. Misuse may be a criminal offence.

The author provides this software "as is" and disclaims liability for misuse. See LICENSE.

Features

  • email — Run ~120 Holehe probes against an email and print a Rich table or JSON.
  • person — Multi-source person lookup. Today: CourtListener (free federal court records via the v4 REST API) and a Playwright scaffold for cyberbackgroundchecks (the site is gated by Cloudflare Turnstile — the source reports blocked with a clear message rather than silently returning zero hits).
  • username — Check a handle across ~460 sites (Sherlock catalogue bundled into the wheel). Filtering via --site, --top, --include-nsfw; concurrency capped via --concurrency; full catalogue with --all.
  • domain — Investigate a domain across three sections: RDAP (via rdap.org) for registrar/dates/status/nameservers, DNS (A/AAAA/MX/NS/TXT/CAA via dnspython), and subdomain enumeration from Certificate Transparency logs (via crt.sh). Section-selectable with --section.
  • breach — Lookup against Have I Been Pwned + DDoSecrets release index.
  • --json flag on every command for clean piping into jq, files, or other tooling.
  • Polite scraping by default (configurable delay, identifiable User-Agent).
  • Typed throughout, mypy --strict clean, formatted with ruff.

Project layout

osint-investigator/
├── pyproject.toml
├── README.md
├── .env.example
├── src/osint_investigator/
│   ├── __init__.py
│   ├── cli.py              # Typer root app
│   ├── config.py           # pydantic-settings, .env loader
│   ├── utils.py            # shared helpers (console, JSON printer, polite sleep)
│   ├── data/               # bundled package data (Sherlock catalogue snapshot)
│   └── modules/
│       ├── __init__.py
│       ├── email_module.py     # Holehe orchestrator
│       ├── person_module.py    # CourtListener + Playwright (Cloudflare-aware)
│       ├── username_module.py  # Sherlock-backed handle probe
│       ├── sherlock_sites.py   # Sherlock data.json loader + site selection
│       ├── domain_module.py    # RDAP + DNS + crt.sh
│       └── breach_module.py    # HIBP + DDoSecrets
└── tests/                  # pytest suite (offline; fixtures under tests/fixtures/)

Install

# Stable release from PyPI
pip install osint-investigator
playwright install chromium  # only needed if you use the `person` cyberbackgroundchecks source

# Or the latest from main
pip install "git+https://github.com/J4y35/osint-investigator.git"

Then (optional) drop a .env next to your shell with an HIBP API key so the breach command can talk to Have I Been Pwned:

echo 'HIBP_API_KEY=your-key-here' > .env

Development quickstart (macOS / Linux)

# 1. Clone the project
git clone https://github.com/J4y35/osint-investigator.git
cd osint-investigator

# 2. Create and activate a virtualenv
python3 -m venv .venv
source .venv/bin/activate

# 3. Install in editable mode + Playwright browsers
pip install --upgrade pip
pip install -e ".[dev]"
playwright install chromium

# 4. Configure
cp .env.example .env
# then edit .env to add HIBP_API_KEY etc. (all optional)

# 5. Verify
osint-investigator --help
pytest -q

Commands

email

Check ~120 sites with Holehe.

osint-investigator email --email someone@gmail.com
osint-investigator email --email someone@gmail.com --json > result.json
osint-investigator email --email someone@gmail.com --only-found

person

Search people-finder sites. Currently wired to cyberbackgroundchecks.com.

osint-investigator person --first Jane --last Doe --state CA

username

Check whether a handle is registered.

osint-investigator username --username johnsmith

breach

Lookup breach corpora (HIBP requires HIBP_API_KEY in .env).

osint-investigator breach --query someone@gmail.com

Configuration

All configuration lives in .env. See .env.example for the full set.

Variable Purpose Default
HIBP_API_KEY Have I Been Pwned API key (unset → HIBP skipped)
HUNTER_API_KEY Hunter.io API key (unset)
INTELX_API_KEY IntelX API key (unset)
OSINT_USER_AGENT UA sent on every request osint-investigator/0.1 …
OSINT_REQUEST_DELAY Politeness delay (seconds) 1.5
OSINT_HTTP_TIMEOUT Per-request timeout (seconds) 20
OSINT_PLAYWRIGHT_HEADLESS Headless browser? true
OSINT_OUTPUT_DIR Where to write JSON exports ./output

Extending

Each subcommand is a self-contained module under src/osint_investigator/modules/. To add a new command:

  1. Create modules/<name>_module.py exposing a Typer instance named app.
  2. Register it in cli.py with app.add_typer(...).
  3. Re-install (pip install -e .) to pick up the entry point — or just rerun.

For people-finder scrapers, mimic _scrape_cyberbackgroundchecks in person_module.py and register the new coroutine in the SCRAPERS dict.

Development

ruff check src tests
ruff format src tests
mypy src
pytest

License

MIT. See pyproject.toml for author info.

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

osint_investigator-0.2.0.tar.gz (125.4 kB view details)

Uploaded Source

Built Distribution

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

osint_investigator-0.2.0-py3-none-any.whl (55.9 kB view details)

Uploaded Python 3

File details

Details for the file osint_investigator-0.2.0.tar.gz.

File metadata

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

File hashes

Hashes for osint_investigator-0.2.0.tar.gz
Algorithm Hash digest
SHA256 4fe8b1c7735422c1bef90ae0ffd34e66dc6b4018713ff0df74cc2c8eb9e7d433
MD5 2279a02715f652f87c3b8478f3b9a483
BLAKE2b-256 e3839f51798b8eb1536c1d989c11ae9f13535ffa3db4988af23e1a1367ba0ff5

See more details on using hashes here.

Provenance

The following attestation bundles were made for osint_investigator-0.2.0.tar.gz:

Publisher: release.yml on J4y35/osint-investigator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file osint_investigator-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for osint_investigator-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 86ab3323b427ce47bd9c4b78136c64e7b01f1ecc7d0274f965ab2a6de732660c
MD5 b3cdbef1b41871e65dd1d0ac4901159f
BLAKE2b-256 7c30c0516d1e3e6f0696d52e292603180b78c0f72708b4b943a43b5f012ead6c

See more details on using hashes here.

Provenance

The following attestation bundles were made for osint_investigator-0.2.0-py3-none-any.whl:

Publisher: release.yml on J4y35/osint-investigator

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