An open API service indexing awesome lists of open source software.

https://github.com/ron4fun/hashlibplus

HashLibPlus is a recommended C++11 hashing library that provides a fluent interface for computing hashes and checksums of strings, files, streams, bytearrays and untyped data to mention but a few.
https://github.com/ron4fun/hashlibplus

argon2 blake-algorithms cpp crc-algorithms crypto cryptography gost hash hmac keccak md5 murmurhash pbkdf2 scrypt sha-hashes siphash snefru tiger whirlpool xof

Last synced: 6 months ago
JSON representation

HashLibPlus is a recommended C++11 hashing library that provides a fluent interface for computing hashes and checksums of strings, files, streams, bytearrays and untyped data to mention but a few.

Awesome Lists containing this project

README

          

HashLibPlus [![License](http://img.shields.io/badge/license-MPL2-blue.svg)](https://github.com/Ron4fun/HashLibPlus/blob/master/LICENSE)
====

HashLibPlus is a recommended C++11 hashing library that provides a fluent interface for computing hashes and checksums of strings, files, streams, bytearrays and untyped data to mention but a few.

It also supports **Incremental Hashing**, **Cloning**, **NullDigest**.

Available Algorithms
----------------------------------------

### Hashes
----------------------------------------
##### Cyclic Redundancy Checks

* `All CRC Variants from CRC3 to CRC64` :heavy_check_mark:

##### Checksums

* `Adler32` :heavy_check_mark:

##### Non-Cryptographic Hash Functions
----------------------------------------

###### 32 bit hashes

* `AP` `BKDR` `Bernstein` `Bernstein1` `DEK` `DJB` `ELF` `FNV` :heavy_check_mark:

* `FNV1a` `JS` `Jenkins3` `Murmur2` `MurmurHash3_x86_32` `OneAtTime` :heavy_check_mark:

* `PJW` `RS` `Rotating` `SDBM` `ShiftAndXor` `SuperFast` `XXHash32` :heavy_check_mark:

###### 64 bit hashes

* `FNV64` `FNV1a64` `Murmur2_64` `SipHash64_2_4` `XXHash64` :heavy_check_mark:

###### 128 bit hashes

* `MurmurHash3_x86_128` `MurmurHash3_x64_128` `SipHash128_2_4` :heavy_check_mark:

##### Cryptographic Hash Functions
----------------------------------------

* `MD2` :heavy_check_mark:

* `MD4` :heavy_check_mark:

* `MD5` :heavy_check_mark:

* `SHA-0` :heavy_check_mark:

* `SHA-1` :heavy_check_mark:

* `SHA-2 (224, 256, 384, 512, 512-224, 512-256)` :heavy_check_mark:

* `GOST 34.11-94` :heavy_check_mark:

* `GOST R 34.11-2012 (AKA Streebog) (256, 512)` :heavy_check_mark:

* `Grindahl (256, 512)` :heavy_check_mark:

* `HAS160` :heavy_check_mark:

* `RIPEMD (128, 256, 256, 320)` :heavy_check_mark:

* `Tiger (128, 160, 192 (Rounds 3, 4, 5))` :heavy_check_mark:

* `Tiger2 (128, 160, 192 (Rounds 3, 4, 5))` :heavy_check_mark:

* `Snefru (128, 256)` :heavy_check_mark:

* `Haval (128, 160, 192, 224, 256 (Rounds 3, 4, 5))` :heavy_check_mark:

* `Panama` :heavy_check_mark:

* `RadioGatun (RadioGatun32, RadioGatun64)` :heavy_check_mark:

* `WhirlPool` :heavy_check_mark:

* `Blake2B (160, 256, 384, 512)` :heavy_check_mark:

* `Blake2S (128, 160, 224, 256)` :heavy_check_mark:

* `SHA-3 (224, 256, 384, 512)` :heavy_check_mark:

* `Keccak (224, 256, 288, 384, 512)` :heavy_check_mark:

* `Blake2BP` :heavy_check_mark:

* `Blake2SP` :heavy_check_mark:

* `Blake3` :heavy_check_mark:

### Key Derivation Functions
----------------------------------------

###### Password Hashing Schemes (Password Based Key Derivation Functions)

----------------------------------------

* `PBKDF2` :heavy_check_mark:

* `Argon2 (2i, 2d and 2id variants)` :heavy_check_mark:

* `Scrypt` :heavy_check_mark:

### MAC
----------------------------------------

* `HMAC (all supported hashes)` :heavy_check_mark:

* `KMAC (KMAC128, KMAC256)` :heavy_check_mark:

* `Blake2MAC (Blake2BMAC, Blake2SMAC)` :heavy_check_mark:

### XOF (Extendable Output Function)
----------------------------------------

* `Shake (Shake-128, Shake-256)` :heavy_check_mark:

* `CShake (CShake-128, CShake-256)` :heavy_check_mark:

* `Blake2X (Blake2XS, Blake2XB)` :heavy_check_mark:

* `KMACXOF (KMAC128XOF, KMAC256XOF)` :heavy_check_mark:

* `Blake3XOF` :heavy_check_mark:

### Usage Examples
----------------------------------------

```c++
#include "Base/HashFactory.h"

int main()
{
IHash hash = HashFactory::Crypto::CreateMD5();

IHash clone = hash->Clone();

IHMAC hmac = HashFactory::HMAC::CreateHMAC(hash);
hmac->SetKey(Converters::ConvertStringToBytes("password"));

IHashResult Result1 = hash->ComputeString("Hash");
IHashResult Result2 = hmac->ComputeString("Hash");

bool check = Result1->CompareTo(Result2);

return 0;
}
```

Full Visual Studio project without CMake
----------------------------------------
Please consider using this version [HashLibPlus-Reload](https://github.com/ron4fun/HashLibPlus-Reload) instead.

How to build library
----------------------------------------
### CMake
----------------------------------------
To build this library you should have [CMake](https://cmake.org) installed and configured on your local machine to work with any *C++* compiler such as **gcc**, **g++** and **clang**. If you already have visual studio installed on your local machine, cmake kind of automatically links with the compiler and therefore builds a visual studio project of the library for you. `Visual Studio 2019` was used to build and compile this project. Goodluck! ;)

*CMake version 2.30.3*, was specifically used to compile this library.

**Note: [catch2](https://github.com/catchorg/Catch2) library was used as the test framework in the `HashLibPlus.Tests` project.**

Follow the steps below to build for x86 (32-bit) Release mode.

```
> cmake -G "Visual Studio 16 2019" -A Win32 -S {src_dir} -B {build_dir}
```

**Example:** `cmake -G "Visual Studio 16 2019" -A Win32 -S . -B x86`

Note: The `.` used as the source directory indicates the current directory where the cmd interface is pointed to.

```
> cmake --build {src_dir} --config Release
```

Follow the steps below to build for x64 (64-bit) Release mode.

```
> cmake -G "Visual Studio 16 2019" -A x64 -S {src_dir} -B {build_dir}
```

**Example:** `cmake -G "Visual Studio 16 2019" -A x64 -S . -B x64`

Note: The `.` used as the source directory indicates the current directory where the cmd interface is pointed to.

```
> cmake --build {src_dir} --config Release
```

This command is to build a `Visual Studio` project files of the library, where *{src_dir}* is the parent directory. And *{build_src}* is the build directory depending on "x86" or "x64".

**Download the project full release [here](https://github.com/ron4fun/HashLibPlus/releases/tag/v1.0)**

How to run test
----------------------------------------
[catch2](https://github.com/catchorg/Catch2) is the test framework used in this project because of its flexible nature.

To run the unitests in *HashLibPlus.Tests* project, locate `HashLibPlus.Test.exe` in the Release folder of the built project.

**The built project outputs two executables and a `hashplus.lib` for linking with the `Base/HashFactory.h` main header file.**

* HashLibPlus.exe
----------------------------------------
This executable displays a benchmark test analysis of the compiled code speed with regards to your C.P.U capability.

* HashLibPlus.Test.exe
----------------------------------------
This executable hooks into [catch2](https://github.com/catchorg/Catch2) process to allow for detailed test results, and other command line options that *catch2* supports for those that wish to pass values to *catch2* interface.

More on this library
----------------------------------------
Depending on how experienced you are with *CMake* or *catch2*, you are always free to make pull requests and most especially plug in your favourite *hash* into the library which might not be available now. Bye!

### Other Implementations
----------------------------------------

If you want implementations in other languages, you can check out these

* [SharpHash](https://github.com/ron4fun/SharpHash) by Mbadiwe Nnaemeka Ronald
* [HashLib4Pascal](https://github.com/Xor-el/HashLib4Pascal) by Ugochukwu Mmaduekwe

### Tip Jar
----------------------------------------

* :dollar: **Bitcoin**: `1Mcci95WffSJnV6PsYG7KD1af1gDfUvLe6`