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
...
- 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) txtorjsonloutput (--format)
python -m venv .venv
# Windows: .venv\Scripts\activate
# macOS/Linux: source .venv/bin/activate
python -m pip install -U pip
pip install -e .pip install -e ".[dev]"wayparam -d example.comwayparam -l domains.txtwayparam -d example.com --stdout --no-fileswayparam -d example.com --stdout --no-files --format jsonlwayparam -d example.com --include-subdomains --rps 1 --concurrency 2wayparam -d example.com --ext-blacklist ".png,.jpg,.css,.js" --exclude-path-regex "^/static/"-
Input parsing
-d/--domainfor a single host-l/--listfor multiple hosts (one per line, supports comments and basic normalization)
-
Query the Wayback CDX API
- Requests are sent to the CDX endpoint (Wayback Machine)
- Uses
matchType=hostby default, ormatchType=domainwhen--include-subdomainsis enabled - Uses pagination (resumeKey) when the API provides it
-
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/, …)
-
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
- replaces values with a placeholder (default
-
Deduplicates results
-
-
Output
- By default writes per-domain results into
results/ --stdoutstreams machine-readable output- Diagnostics (hints, logs, stats) go to stderr (safe for pipelines)
- By default writes per-domain results into
- stdout: only results (URLs or JSONL) when
--stdoutis 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--include-subdomains--from 2019/--to 2021(or full timestamps like20190101000000)--filter statuscode:200(repeatable)--no-collapse(more duplicates, more data)
--placeholder X--keep-values(not recommended if you share logs)--drop-tracking/--no-drop-tracking--all-urls(include URLs without query parameters)
--ext-blacklist ".png,.jpg,.css,.js"--ext-whitelist ".php,.asp,.aspx"--exclude-path-regex "regex"(repeatable)
--concurrency 8--rps 1(recommended when using VPNs / noisy networks)--timeout 30--retries 4--proxy http://127.0.0.1:8080
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
--concurrencyand setting--rps 1
wayparam will print a human-readable hint in English to stderr when it detects this pattern.
A manual page is included:
man ./man/wayparam.1Install dev dependencies and run:
pip install -e ".[dev]"
pytest -qThe test suite includes httpx-level integration tests using httpx.MockTransport (no network).
wayparam is free software released under the GNU General Public License v3 (GPLv3).
See the LICENSE file for details.
- 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.
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.