2020-11-09 05:23:58 +01:00
|
|
|
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
2016-01-29 00:24:27 +01:00
|
|
|
|
2017-10-03 10:41:51 +02:00
|
|
|
#if HAVE_GCRYPT
|
2016-01-29 00:24:27 +01:00
|
|
|
|
|
|
|
#include "gcrypt-util.h"
|
2016-03-27 23:33:54 +02:00
|
|
|
#include "hexdecoct.h"
|
2016-01-29 00:24:27 +01:00
|
|
|
|
|
|
|
void initialize_libgcrypt(bool secmem) {
|
|
|
|
if (gcry_control(GCRYCTL_INITIALIZATION_FINISHED_P))
|
|
|
|
return;
|
|
|
|
|
2019-03-27 14:28:24 +01:00
|
|
|
assert_se(gcry_check_version("1.4.5"));
|
2016-01-29 00:24:27 +01:00
|
|
|
|
2016-02-08 13:27:22 +01:00
|
|
|
/* Turn off "secmem". Clients which wish to make use of this
|
2016-01-29 00:24:27 +01:00
|
|
|
* feature should initialize the library manually */
|
|
|
|
if (!secmem)
|
|
|
|
gcry_control(GCRYCTL_DISABLE_SECMEM);
|
|
|
|
gcry_control(GCRYCTL_INITIALIZATION_FINISHED, 0);
|
|
|
|
}
|
2016-01-29 00:24:27 +01:00
|
|
|
|
|
|
|
int string_hashsum(const char *s, size_t len, int md_algorithm, char **out) {
|
2018-02-05 09:54:57 +01:00
|
|
|
_cleanup_(gcry_md_closep) gcry_md_hd_t md = NULL;
|
2016-01-29 00:24:27 +01:00
|
|
|
size_t hash_size;
|
|
|
|
void *hash;
|
|
|
|
char *enc;
|
|
|
|
|
|
|
|
initialize_libgcrypt(false);
|
|
|
|
|
|
|
|
hash_size = gcry_md_get_algo_dlen(md_algorithm);
|
|
|
|
assert(hash_size > 0);
|
|
|
|
|
|
|
|
gcry_md_open(&md, md_algorithm, 0);
|
|
|
|
if (!md)
|
|
|
|
return -EIO;
|
|
|
|
|
|
|
|
gcry_md_write(md, s, len);
|
|
|
|
|
|
|
|
hash = gcry_md_read(md, 0);
|
|
|
|
if (!hash)
|
|
|
|
return -EIO;
|
|
|
|
|
|
|
|
enc = hexmem(hash, hash_size);
|
|
|
|
if (!enc)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
*out = enc;
|
|
|
|
return 0;
|
|
|
|
}
|
2016-03-27 23:33:54 +02:00
|
|
|
#endif
|