diff options
author | Gökhan Şengün <gsengun@linux-5d7d.site> | 2012-03-30 23:09:47 +0300 |
---|---|---|
committer | Steve Holme <steve_holme@hotmail.com> | 2012-03-31 22:31:16 +0100 |
commit | 004d7251ab1abca0b3e1c6e632eef12e335f3aaa (patch) | |
tree | 78f4fd6db5aae6ef5e030a9e00e05c7c4adfc461 /lib/curl_md5.h | |
parent | 33d044a8628ac40418e1e5e698b0fd90c722a07f (diff) | |
download | curl-004d7251ab1abca0b3e1c6e632eef12e335f3aaa.tar.gz |
md5: Add support for calculating the md5 sum of buffers incrementally
It is now possible to calculate the md5 sum as the stream of buffers
becomes known where as previously it was only possible to calculate the
md5 sum of a pre-prepared buffer.
Diffstat (limited to 'lib/curl_md5.h')
-rw-r--r-- | lib/curl_md5.h | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/lib/curl_md5.h b/lib/curl_md5.h index ddc61e3e5..b445500fc 100644 --- a/lib/curl_md5.h +++ b/lib/curl_md5.h @@ -25,10 +25,39 @@ #ifndef CURL_DISABLE_CRYPTO_AUTH #include "curl_hmac.h" +#define MD5_DIGEST_LEN 16 + +typedef void (* Curl_MD5_init_func)(void *context); +typedef void (* Curl_MD5_update_func)(void *context, + const unsigned char *data, + unsigned int len); +typedef void (* Curl_MD5_final_func)(unsigned char *result, void *context); + +typedef struct { + Curl_MD5_init_func md5_init; /* Initialize context procedure */ + Curl_MD5_update_func md5_update; /* Update context with data */ + Curl_MD5_final_func md5_final; /* Get final result procedure */ + unsigned int md5_ctxtsize; /* Context structure size */ + unsigned int md5_resultlen; /* Result length (bytes) */ +} MD5_params; + +typedef struct { + const MD5_params *md5_hash; /* Hash function definition */ + void *md5_hashctx; /* Hash function context */ +} MD5_context; + +extern const MD5_params Curl_DIGEST_MD5[1]; extern const HMAC_params Curl_HMAC_MD5[1]; void Curl_md5it(unsigned char *output, const unsigned char *input); + +MD5_context * Curl_MD5_init(const MD5_params *md5params); +int Curl_MD5_update(MD5_context *context, + const unsigned char *data, + unsigned int len); +int Curl_MD5_final(MD5_context *context, unsigned char *result); + #endif #endif /* HEADER_CURL_MD5_H */ |