Prototype Pollution Fuzzer
A fast tool to scan prototype pollution vulnerability written in Rust. 🦀
Simply, download a pre-built binary from releases page and run!
NOTE: Rust should be installed! |
Using cargo
:
bash
â–¶ cargo install ppfuzz
Manual building executable from source code:
bash
â–¶ git clone https://github.com/dwisiswant0/ppfuzz
â–¶ cd ppfuzz && cargo build --release
ppfuzz uses chromiumoxide, which requires the Chrome or Chromium browser to be installed.
If the CHROME
environment variable is set, then it'll use it as the default executable. Otherwise, the filenames google-chrome-stable
, chromium
, chromium-browser
, chrome
and chrome-browser
are searched for in standard places. If that fails, /Applications/Google Chrome.app/...
(on MacOS) or the registry (on Windows) is consulted.
It's fairly simple to use ppfuzz!
bash
â–¶ ppfuzz -l FILE [OPTIONS]
Use -l/--list
to provide input list:
bash
â–¶ ppfuzz -l FILE
You can also provide the list using I/O redirection:
bash
â–¶ ppfuzz < FILE
— or chain it from another command output:
bash
â–¶ cat FILE | ppfuzz
Only show vulnerable targets/suppress an errors:
bash
â–¶ ppfuzz -l FILE 2>/dev/null
Here are all the options it supports:
bash
â–¶ ppfuzz -h
| Flag | Description | Default value | |------------------- |---------------------------------------- |------------------- | | -l, --list | List of target URLs | | | -c, --concurrency | Set the concurrency level | 5 | | -t, --timeout | Max. time allowed for connection (s) | 30 | | -h, --help | Prints help information | | | -V, --version | Prints version information | |
When I started out ppfuzz, I had very little or no knowledge on Rust and I believe there may be a lot of drawbacks/security vulnerabilities. So all contributions are welcome, of course — any bug reports & suggestions are appreciated, some environment have not been tested yet.
Besides being my learning medium, this tool was created because it was inspired by a tip shared by @R0X4R on how to automate prototype pollution checking using page-fetch.
Cross-compile GitHub workflow inspired by crodjer's sysit.
Since this tool includes some contributions, I'll publically thank the following users for their helps and resources:
Fourty2#4842
(Discord) - for helpful workaround.ppfuzz is distributed under MIT license. See LICENSE
.