Skip to content

aleff-github/wayparam

wayparam

wayparam is a modern, cross-platform CLI tool to fetch historical URLs from the Internet Archive Wayback CDX API, filter out “boring” URLs (static assets), and normalize query parameters so you can focus on endpoints that actually matter.

This project is inspired by ParamSpider (same overall goal, completely rewritten with a more robust architecture, modern async I/O, better filtering, and production-friendly output behavior).

OSINT tool: wayparam does not crawl targets. It only queries the Wayback CDX API.

Convert this example.com into something like this:

...
http://www.example.com/_next/image?q=FUZZ&url=FUZZ&w=FUZZ
https://www.example.com/_Incapsula_Resource?SWJIYLWA=FUZZ
http://www.example.com/?format=FUZZ&retailerId=FUZZ
...

Key features

  • Wayback CDX API URL collection (single domain or list)
  • Async + concurrency for speed on multiple domains
  • Rate limiting (--rps) to be polite with Wayback/CDX
  • Retry + backoff and clearer error messages
  • CDX pagination (resumeKey) when available
  • Filters “boring” URLs by:
    • extension blacklist/whitelist
    • optional path regex exclusion
  • Canonicalization & normalization
    • drop fragments
    • normalize host/ports
    • sort parameters
    • mask parameter values (default placeholder: FUZZ)
    • optional tracking parameter removal (utm_*, gclid, fbclid, …)
  • Output:
    • per-domain files (default)
    • stdout streaming for pipelines (--stdout)
    • txt or jsonl output (--format)

Installation

From source (recommended for now)

python -m venv .venv
# Windows: .venv\Scripts\activate
# macOS/Linux: source .venv/bin/activate
python -m pip install -U pip
pip install -e .

Development install (tests + lint)

pip install -e ".[dev]"

Quick start

1) Single domain (writes to results/)

wayparam -d example.com

2) List of domains

wayparam -l domains.txt

3) Stream to stdout (for piping), no files

wayparam -d example.com --stdout --no-files

4) JSONL output (great for tooling)

wayparam -d example.com --stdout --no-files --format jsonl

5) Include subdomains + be polite to Wayback

wayparam -d example.com --include-subdomains --rps 1 --concurrency 2

6) Customize filtering (extensions + path regex)

wayparam -d example.com --ext-blacklist ".png,.jpg,.css,.js" --exclude-path-regex "^/static/"

How it works (under the hood)

  1. Input parsing

    • -d/--domain for a single host
    • -l/--list for multiple hosts (one per line, supports comments and basic normalization)
  2. Query the Wayback CDX API

    • Requests are sent to the CDX endpoint (Wayback Machine)
    • Uses matchType=host by default, or matchType=domain when --include-subdomains is enabled
    • Uses pagination (resumeKey) when the API provides it
  3. Filter “boring” URLs

    • Drops URLs that look like static assets (by extension), with optional whitelist mode
    • Optional regex filters can exclude paths (e.g., /static/, /assets/, …)
  4. Canonicalize + normalize

    • Removes fragments (#...)

    • Normalizes default ports (:80, :443)

    • Parses query string and:

      • replaces values with a placeholder (default FUZZ)
      • optionally drops tracking parameters
      • sorts parameters for stable output
    • Deduplicates results

  5. Output

    • By default writes per-domain results into results/
    • --stdout streams machine-readable output
    • Diagnostics (hints, logs, stats) go to stderr (safe for pipelines)

Output behavior (important for pipelines)

  • stdout: only results (URLs or JSONL) when --stdout is enabled
  • stderr: logs, errors, hints (VPN/proxy), optional stats

This means you can safely do:

wayparam -d example.com --stdout --no-files | sort -u > urls.txt

Common options

Wayback/CDX

  • --include-subdomains
  • --from 2019 / --to 2021 (or full timestamps like 20190101000000)
  • --filter statuscode:200 (repeatable)
  • --no-collapse (more duplicates, more data)

Normalization

  • --placeholder X
  • --keep-values (not recommended if you share logs)
  • --drop-tracking / --no-drop-tracking
  • --all-urls (include URLs without query parameters)

Filtering

  • --ext-blacklist ".png,.jpg,.css,.js"
  • --ext-whitelist ".php,.asp,.aspx"
  • --exclude-path-regex "regex" (repeatable)

Performance / network

  • --concurrency 8
  • --rps 1 (recommended when using VPNs / noisy networks)
  • --timeout 30
  • --retries 4
  • --proxy http://127.0.0.1:8080

Troubleshooting: VPN / Proxy issues (Wayback CDX)

If you see errors like “failed after retries” against the CDX endpoint, it often means:

  • the VPN/proxy exit node is blocked or rate-limited by Wayback
  • your VPN does TLS filtering or networking policies that break automated requests

Try:

  • disconnecting VPN/proxy and rerunning
  • switching to a different VPN server
  • lowering --concurrency and setting --rps 1

wayparam will print a human-readable hint in English to stderr when it detects this pattern.


Man page

A manual page is included:

man ./man/wayparam.1

Testing

Install dev dependencies and run:

pip install -e ".[dev]"
pytest -q

The test suite includes httpx-level integration tests using httpx.MockTransport (no network).


License

wayparam is free software released under the GNU General Public License v3 (GPLv3). See the LICENSE file for details.


Acknowledgements

  • Inspired by ParamSpider (same objective: fetch Wayback URLs, filter noise, focus on parameterized endpoints).
  • Thanks to the OSINT / security community for patterns and workflows around URL collection and parameter discovery.

Disclaimer

Use responsibly and lawfully. This tool queries the Internet Archive and does not actively scan targets, but your downstream usage of collected URLs may have legal and ethical implications depending on context.

About

Fetch and normalize parameterized URLs from the Wayback CDX API (OSINT, inspired by ParamSpider).

Topics

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Languages