Expand description

This library helps you to brute force hashes (e.g. passwords). It includes a set of pre-configured hashing functions, like md5 (crate::hash_fncs::md5_hashing), sha1 (crate::hash_fncs::sha1_hashing), or sha256 (crate::hash_fncs::sha256_hashing). You can also provide your own hashing function. PLEASE DO NOT use this software to harm someones privacy in any kind! This project was made for fun and for teaching myself new things about Rust.

The main function of this crate is crack<T: CrackTarget>().

Minimal example

use libbruteforce::{BasicCrackParameter, CrackParameter, TargetHashInput};
use libbruteforce::hash_fncs::sha256_hashing;
use libbruteforce::symbols;

// sha256("a+c")
let sha256_hash = "3d7edde33628331676b39e19a3f2bdb3c583960ad8d865351a32e2ace7d8e02d";
let max_len = 3;
let min_len = 0;
let alphabet = symbols::Builder::new().with_digits().build();

let res = CrackParameter::new(
        BasicCrackParameter::new(alphabet, max_len, min_len, false),
        sha256_hashing(TargetHashInput::HashAsStr(sha256_hash)),
);

Modules

Pre-defined hashing functions that you might use.

This module contains prebuilt alphabets/symbols that you can use.

Structs

Describes the necessary parameters for the crate::crack<T: CrackTarget>()-function without the generic part that is outsourced to crate::TargetHashAndHashFunction.

Crack parameter for crate::crack<T: CrackTarget>(). It combines the basic struct BasicCrackParameter with the generic TargetHashAndHashFunction. This separation exists so that hash selection functions can be written more convenient.

Describes the result of a finished cracking process.

Abstraction over a hashing algorithm and the target hash that needs to be cracked. T is of type CrackTarget. This generic struct exists so that hashes of type CrackTarget can be checked independent of the hashing algorithm. This is more efficient than transforming every hash to a string and compare the hash string representations afterwards.

Enums

Helper type to create instances of TargetHashAndHashFunction.

Traits

Common trait for crack targets (hashes or plain text to crack). This is the super-type which enables the usage of multiple hashing algorithms. An example that implements this/fulfils the trait requirements is String.

Functions

This function starts a multi-threaded brute force attack on a given target string. It supports any alphabet you would like to use. You must provide a hashing function. There is a pre-build set of transformation functions available, such as hash_fncs::no_hashing or hash_fncs::sha256_hashing. You can also provide your own hashing strategy.