diff options
author | Nick Mathewson <nickm@torproject.org> | 2013-04-18 11:16:05 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2013-04-18 11:16:05 -0400 |
commit | da30adcf0fd048d1f2e7a4b76e2c880cc3824e6e (patch) | |
tree | eef8ad038eb361e3241c3b8f9997478c8522ce55 /src/common/crypto.c | |
parent | 5f035e2c6501fe166900cb493e2c3de51371c9c5 (diff) | |
parent | 9fec0c1a95ab24f5f18d6995e30fe2111e6b7db2 (diff) | |
download | tor-da30adcf0fd048d1f2e7a4b76e2c880cc3824e6e.tar.gz tor-da30adcf0fd048d1f2e7a4b76e2c880cc3824e6e.zip |
Merge remote-tracking branch 'origin/maint-0.2.4'
Conflicts:
src/common/crypto.c
Diffstat (limited to 'src/common/crypto.c')
-rw-r--r-- | src/common/crypto.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/src/common/crypto.c b/src/common/crypto.c index 1b5b558a6f..31a0df1ed7 100644 --- a/src/common/crypto.c +++ b/src/common/crypto.c @@ -1614,6 +1614,29 @@ crypto_digest_assign(crypto_digest_t *into, memcpy(into,from,sizeof(crypto_digest_t)); } +/** Given a list of strings in <b>lst</b>, set the <b>len_out</b>-byte digest + * at <b>digest_out</b> to the hash of the concatenation of those strings, + * plus the optional string <b>append</b>, computed with the algorithm + * <b>alg</b>. + * <b>out_len</b> must be \<= DIGEST256_LEN. */ +void +crypto_digest_smartlist(char *digest_out, size_t len_out, + const smartlist_t *lst, const char *append, + digest_algorithm_t alg) +{ + crypto_digest_t *d; + if (alg == DIGEST_SHA1) + d = crypto_digest_new(); + else + d = crypto_digest256_new(alg); + SMARTLIST_FOREACH(lst, const char *, cp, + crypto_digest_add_bytes(d, cp, strlen(cp))); + if (append) + crypto_digest_add_bytes(d, append, strlen(append)); + crypto_digest_get_digest(d, digest_out, len_out); + crypto_digest_free(d); +} + /** Compute the HMAC-SHA-256 of the <b>msg_len</b> bytes in <b>msg</b>, using * the <b>key</b> of length <b>key_len</b>. Store the DIGEST256_LEN-byte * result in <b>hmac_out</b>. |