mhash - Hash Library
mhash 0.8.4
#include "mhash.h"
Informative Functions
size_t mhash_count(void); size_t mhash_get_block_size(hashid type); char *mhash_get_hash_name(hashid type); size_t mhash_get_hash_pblock(hashid type); hashid mhash_get_mhash_algo( MHASH);
Key Generation Functions
int mhash_keygen_ext(keygenid algorithm, KEYGEN algorithm_data, void* keyword, int keysize, unsigned char* password, int passwordlen);
Initializing Functions
MHASH mhash_init(hashid type); MHASH mhash_hmac_init(const hashid type, void *key, int keysize, int block); MHASH mhash_cp( MHASH);
Update Functions
int mhash(MHASH thread, const void *plaintext, size_t size);
Finalizing Functions
void *mhash_end(MHASH thread); void *mhash_hmac_end(MHASH thread); void *mhash_end_m(MHASH thread, void* (*hash_malloc)(size_t)); void *mhash_hmac_end_m(MHASH thread, void* (*hash_malloc)(size_t));
Available Hashes
enum hashid { MHASH_CRC32, MHASH_MD5, MHASH_SHA1, MHASH_HAVAL256, MHASH_RIPEMD160, MHASH_TIGER, MHASH_GOST, MHASH_CRC32B, MHASH_HAVAL192=11, MHASH_HAVAL160, MHASH_HAVAL128 };
typedef enum hashid hashid;
Available Key Generation algorithms
enum keygenid { KEYGEN_MCRYPT, /* The key generator used in mcrypt */ KEYGEN_ASIS, /* Just returns the password as binary key */ KEYGEN_HEX, /* Just converts a hex key into a binary one */ KEYGEN_PKDES, /* The transformation used in Phil Karn's DES * encryption program */ KEYGEN_S2K_SIMPLE, /* The OpenPGP (rfc2440) Simple S2K */ KEYGEN_S2K_SALTED, /* The OpenPGP Salted S2K */ KEYGEN_S2K_ISALTED /* The OpenPGP Iterated Salted S2K */ };
typedef enum keygenid keygenid;
The mhash library provides an easy to use C interface for several hash algorithms (also known as ``one-way'' algorithms). These can be used to create checksums, message digests and more. Currently, MD5, SHA1, GOST, TIGER, RIPE-MD160, HAVAL and several other algorithms are supported. mhash support HMAC generation (a mechanism for message authentication using cryptographic hash functions, and is described in rfc2104). HMAC can be used to create message digests using a secret key, so that these message digests cannot be regenerated (or replaced) by someone else. A key generation mechanism was added to mhash since key generation algorithms usually involve hash algorithms.
We will describe the API of mhash in detail now. The order follows the one in the SYNOPSIS directly.
This returns the hashid of the last available hash. Hashes are numbered from 0 to mhash_count()
.
If type exists, this returns the used blocksize of the hash type in bytes. Otherwise, it returns 0.
If type exists, this returns the name of the hash type. Otherwise, a
NULL
pointer is returned. The string is allocated with malloc(3)
seperately, so do not forget to free(3)
it.
It returns the block size that the algorithm operates. This is used in mhash_hmac_init. If the return value is 0 you shouldn't use that algorithm in HMAC.
Returns the algorithm used in the state of src.
This setups a context to begin hashing using the algorithm type. It returns a descriptor to that context which will result in leaking
memory, if you do not call mhash_end(3)
later. Returns MHASH_FAILED
on failure.
This setups a context to begin hashing using the algorithm type in
HMAC mode.
key should be a pointer to the key and keysize its len. The block is the block size (in bytes) that the algorithm operates. It should be
obtained by mhash_get_hash_pblock().
If its 0 it defaults to
64. After calling it you should use mhash()
to update the
context. It returns a descriptor to that context which will result in
leaking memory, if you do not call mhash_hmac_end(3)
later.
Returns MHASH_FAILED
on failure.
This setups a new context using the state of src.
This updates the context described by thread with plaintext. size is the length of plaintext which may be binary data.
This frees all resources associated with thread and returns the result of the whole hashing operation (the ``digest'').
This frees all resources associated with thread and returns the result of the whole hashing operation (the ``mac'').
This frees all resources associated with thread and returns the result of the whole hashing operation (the ``digest''). The result will be allocated by using the hash_malloc()
function provided.
This frees all resources associated with thread and returns the result of
the whole hashing operation (the ``mac''). The result will be allocated by using the hash_malloc()
function provided.
We will now describe the Key Generation API of mhash in detail.
This function, generates a key from a password. The password is read from password and it's len should be in passwordlen. The key generation algorithm is specified in algorithm, and that algorithm may (internally) use the KEYGEN structure. The KEYGEN structure consists of: typedef struct keygen { hashid hash_algorithm[2]; unsigned int count; void* salt; int salt_size; } KEYGEN;
The algorithm(s)
specified in algorithm_data.hash_algorithm, should be hash algorithms and may be used by the key generation algorithm. Some key generation algorithms may use more than one hash algorithms (view also mhash_keygen_uses_hash_algorithm()).
If it is desirable (and supported by the algorithm, eg.
KEYGEN_S2K_SALTED) a salt may be specified in
algorithm_data.salt of size algorithm_data.salt_size
or may be
NULL.
The algorithm may use the algorithm_data.count internally (eg. KEYGEN_S2K_ISALTED). The generated keyword is stored in keyword, which should be (at least) keysize bytes long. The generated keyword is a binary one.
This function returns 1 if the specified key generation algorithm needs a salt to be specified.
This function returns 1 if the specified key generation algorithm needs the
algorithm_data.count field in mhash_keygen_ext().
The count
field tells the algorithm to hash repeatedly the password and to stop when count bytes have been processed.
This function returns the size of the salt size, that the specific algorithm will use. If it returns 0, then there is no limitation in the size.
This function returns the maximum size of the key, that the key generation algorithm may produce. If it returns 0, then there is no limitation in the size.
This function returns the number of the hash algorithms the key generation
algorithm will use. If it is 0 then no hash algorithm is used by the key
generation algorithm. This is for the algorithm_data.hash_algorithm field in mhash_keygen_ext().
If
This returns the keygenid
of the last available key generation algorithm. Algorithms are numbered
from 0 to mhash_keygen_count()
.
If type exists, this returns the name of the keygen type. Otherwise, a
NULL
pointer is returned. The string is allocated with malloc(3)
seperately, so do not forget to free(3)
it.
Hashing STDIN until EOF.
#include <mhash.h> #include <stdio.h> #include <stdlib.h>
int main(void) { int i; MHASH td; unsigned char buffer; unsigned char *hash;
td = mhash_init(MHASH_MD5);
if (td == MHASH_FAILED) exit(1);
while (fread(&buffer, 1, 1, stdin) == 1) { mhash(td, &buffer, 1); }
hash = mhash_end(td);
printf("Hash:"); for (i = 0; i < mhash_get_block_size(MHASH_MD5); i++) { printf("%.2x", hash[i]); } printf("\n");
exit(0); }
An example program using HMAC:
#include <mhash.h> #include <stdio.h>
int main() {
char password[] = "Jefe"; int keylen = 4; char data[] = "what do ya want for nothing?"; int datalen = 28; MHASH td; unsigned char *mac; int j; td = mhash_hmac_init(MHASH_MD5, password, keylen, mhash_get_hash_pblock(MHASH_MD5));
mhash(td, data, datalen); mac = mhash_hmac_end(td);
/* * The output should be 0x750c783e6ab0b503eaa86e310a5db738 * according to RFC 2104. */
printf("0x"); for (j = 0; j < mhash_get_block_size(MHASH_MD5); j++) { printf("%.2x", mac[j]); } printf("\n"); exit(0); }
This library was originally written by Nikos Mavroyanopoulos <nmav@hellug.gr> who passed the project over to Sascha Schumann <sascha@schumann.cx> in May 1999. Sascha maintained it until March 2000. The library is now maintained by Nikos Mavroyanopoulos.
If you find any, please send a bug report (preferrably together with a patch) to the maintainer with a detailed description on how to reproduce the bug.
Sascha Schumann <sascha@schumann.cx> Nikos Mavroyanopoulos <nmav@hellug.gr>