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.1.tar.gz (126.2 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.1-py3-none-any.whl (56.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: osint_investigator-0.2.1.tar.gz
  • Upload date:
  • Size: 126.2 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.1.tar.gz
Algorithm Hash digest
SHA256 6b9ce98c95c46696434de5cd63f60a548fab8ab05a9d238cf63898e8b3b9460f
MD5 79085329fcb68e91b48b3f5494ce9ccf
BLAKE2b-256 66e4dc2e7df38c0fb7ee21ccf83b9bf3ba18b7a5c799dca92c90dd0d77a75585

See more details on using hashes here.

Provenance

The following attestation bundles were made for osint_investigator-0.2.1.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.1-py3-none-any.whl.

File metadata

File hashes

Hashes for osint_investigator-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e53fc0d1598b71efb6b4a909a7faef1b1815a48a73c0afd97109c5e5bb02fac1
MD5 c9174b21871741b2e6879555557d6784
BLAKE2b-256 13698ffd25d01742ca584408df50bf24f51dd25e41eb7f99c7b15812a35a39b9

See more details on using hashes here.

Provenance

The following attestation bundles were made for osint_investigator-0.2.1-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