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.
⚠️ 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 reportsblockedwith 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 (viardap.org) for registrar/dates/status/nameservers, DNS (A/AAAA/MX/NS/TXT/CAA viadnspython), and subdomain enumeration from Certificate Transparency logs (viacrt.sh). Section-selectable with--section.breach— Lookup against Have I Been Pwned + DDoSecrets release index.--jsonflag on every command for clean piping intojq, files, or other tooling.- Polite scraping by default (configurable delay, identifiable User-Agent).
- Typed throughout,
mypy --strictclean, formatted withruff.
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:
- Create
modules/<name>_module.pyexposing aTyperinstance namedapp. - Register it in
cli.pywithapp.add_typer(...). - 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6b9ce98c95c46696434de5cd63f60a548fab8ab05a9d238cf63898e8b3b9460f
|
|
| MD5 |
79085329fcb68e91b48b3f5494ce9ccf
|
|
| BLAKE2b-256 |
66e4dc2e7df38c0fb7ee21ccf83b9bf3ba18b7a5c799dca92c90dd0d77a75585
|
Provenance
The following attestation bundles were made for osint_investigator-0.2.1.tar.gz:
Publisher:
release.yml on J4y35/osint-investigator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
osint_investigator-0.2.1.tar.gz -
Subject digest:
6b9ce98c95c46696434de5cd63f60a548fab8ab05a9d238cf63898e8b3b9460f - Sigstore transparency entry: 1618944737
- Sigstore integration time:
-
Permalink:
J4y35/osint-investigator@a5f52e20bd2ef64e238aad084ed146eedb7e4a17 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/J4y35
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@a5f52e20bd2ef64e238aad084ed146eedb7e4a17 -
Trigger Event:
push
-
Statement type:
File details
Details for the file osint_investigator-0.2.1-py3-none-any.whl.
File metadata
- Download URL: osint_investigator-0.2.1-py3-none-any.whl
- Upload date:
- Size: 56.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e53fc0d1598b71efb6b4a909a7faef1b1815a48a73c0afd97109c5e5bb02fac1
|
|
| MD5 |
c9174b21871741b2e6879555557d6784
|
|
| BLAKE2b-256 |
13698ffd25d01742ca584408df50bf24f51dd25e41eb7f99c7b15812a35a39b9
|
Provenance
The following attestation bundles were made for osint_investigator-0.2.1-py3-none-any.whl:
Publisher:
release.yml on J4y35/osint-investigator
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
osint_investigator-0.2.1-py3-none-any.whl -
Subject digest:
e53fc0d1598b71efb6b4a909a7faef1b1815a48a73c0afd97109c5e5bb02fac1 - Sigstore transparency entry: 1618944909
- Sigstore integration time:
-
Permalink:
J4y35/osint-investigator@a5f52e20bd2ef64e238aad084ed146eedb7e4a17 -
Branch / Tag:
refs/tags/v0.2.1 - Owner: https://github.com/J4y35
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@a5f52e20bd2ef64e238aad084ed146eedb7e4a17 -
Trigger Event:
push
-
Statement type: