53 releases

0.10.0 Sep 3, 2024
0.9.6 Jun 8, 2024
0.9.4 Mar 10, 2024
0.9.0 Dec 19, 2023
0.2.2 Nov 4, 2020

#586 in Cryptography

MIT license

54KB
1.5K SLoC

rustgenhash

rustgenhash is a tool to generate hashes on the commandline from stdio.

It can be used to generate single or multiple hashes for usage in password databases or even in penetration testing scenarios where you want to test password cracking tools. It can also help to identify the nature of a provided hash.

Install

rustgenhash is written in Rust. You can install the tool with your Rust installation using following command:

cargo install rustgenhash

Usage

Rustgenhash has a command line interface which allows you to set the utility into a specific operating mode. The current modes are

  • analyze
  • benchmark
  • compare-hash
  • random
  • stdio
  • string
  • file
  • header
  • interactive

After selecting the mode you will need to provide the -a switch for selecting a suitable hashing algorithm and a string or file to be hashed. The stdio mode allows you to pipe to the rgh command. The tool will hash the passed lines from the stdio (useful for hashing password lists).

The file mode supports hashing of multiple files in a directory and currently works non-recursive.

Scheme for string hashing:

rgh string -a <algorithm> <string>

Scheme for file hashing:

rgh file -a <algorithm> <filename or directory>

Scheme for string hashing from stdio:

cat myfile | rgh stdio -a <algorithm>
echo "mypassword" | rgh stdio -a <algorithm>

Scheme for analyzing a hash:

rgh analyze -a <algorithm> <hash>

Scheme for generating a HHHash of a provided url:

rgh header www.google.de

Scheme for comparing a hash:

rgh compare-string <hash1> <hash2>

Scheme for comparing hash files with each other:

rgh compare-file <file1> <file2>

Scheme for benchmarking a hash algorithm:

rgh benchmark -a <algorithm> -i <iterations>

You can list all supported algorithms over the help function.

Lastly, the tool offers the interactive mode:

rgh interactive

Contribution

If you want to contribute to this project, please feel free to do so. I am happy to accept pull requests. Any help is appreciated. If you have any questions, please feel free to contact me.

Dependencies

~18–33MB
~511K SLoC