rwalk

0

A blazingly fast web directory scanner written in Rust

Security

web
rust
fuzzing

rwalk

Crates.io GitHub Release

A blazingly fast web directory scanner written in Rust. It's like dirsearch but on steroids. It is designed to be fast in recursive scans and to be able to handle large wordlists.

Unlike other tools, rwalk does not provide advanced fuzzing features such as parameter fuzzing, header discovery, etc.

Quick Installation

On Nix

# without flakes:
nix-env -iA nixpkgs.rwalk
# with flakes:
nix profile install nixpkgs#rwalk

From homebrew

brew install cestef/tap/rwalk

With cargo-binstall

cargo binstall rwalk

From crates.io

cargo install rwalk

You can also download the latest binary from the releases page.

Documentation

The full documentation can be found at https://rwalk.cstef.dev.

Task Runner

This project uses braisé as a task runner. You can find all the available tasks in the braise.toml file.

Benchmarks

The following benchmarks were run on a 2023 MacBook Pro with an M3 Pro chip on a 10 Gbps connection via WiFi. The target was http://ffuf.me/cd/basic and the wordlist was common.txt.

Each tool was run 10 times with 100 threads. The results are below:

CommandMean [s]Min [s]Max [s]Relative
rwalk2.406 ± 0.0942.2732.5391.00
dirsearch8.528 ± 0.1498.2788.7433.54 ± 0.15
ffuf2.552 ± 0.1812.3803.0051.06 ± 0.09

If you want to run the benchmarks yourself, you can use the bench command:

br bench

Arguments can also be passed to the bench command:

URL="http://ffuf.me/cd/basic" br bench

Please take these results with a grain of salt.

"There are three types of lies: lies, damned lies and benchmarks"

Contributing

Contributions are welcome! I am always looking for new ideas and improvements.

If you want to contribute to rwalk, please read the CONTRIBUTING.md file.

Make sure that your commits follow the Conventional Commits standard. This project uses commitizen to help you with that.

License

Licensed under the MIT License.