mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 05:07:42 +03:00
util.hashes: Return OpenSSL error messages on failure
With luck, might contain more details than just "failed"
This commit is contained in:
parent
a7567a9055
commit
9a96021706
1 changed files with 4 additions and 3 deletions
|
@ -28,6 +28,7 @@ typedef unsigned __int32 uint32_t;
|
|||
#include <openssl/md5.h>
|
||||
#include <openssl/hmac.h>
|
||||
#include <openssl/evp.h>
|
||||
#include <openssl/err.h>
|
||||
|
||||
#if (LUA_VERSION_NUM == 501)
|
||||
#define luaL_setfuncs(L, R, N) luaL_register(L, NULL, R)
|
||||
|
@ -85,7 +86,7 @@ static int Levp_hash(lua_State *L, const EVP_MD *evp) {
|
|||
|
||||
fail:
|
||||
EVP_MD_CTX_free(ctx);
|
||||
return luaL_error(L, "hash function failed");
|
||||
return luaL_error(L, ERR_error_string(ERR_get_error(), NULL));
|
||||
}
|
||||
|
||||
static int Lsha1(lua_State *L) {
|
||||
|
@ -178,7 +179,7 @@ static int Levp_hmac(lua_State *L, const EVP_MD *evp) {
|
|||
fail:
|
||||
EVP_MD_CTX_free(ctx);
|
||||
EVP_PKEY_free(pkey);
|
||||
return luaL_error(L, "hash function failed");
|
||||
return luaL_error(L, ERR_error_string(ERR_get_error(), NULL));
|
||||
}
|
||||
|
||||
static int Lhmac_sha1(lua_State *L) {
|
||||
|
@ -231,7 +232,7 @@ static int Levp_pbkdf2(lua_State *L, const EVP_MD *evp, size_t out_len) {
|
|||
const int iter = luaL_checkinteger(L, 3);
|
||||
|
||||
if(PKCS5_PBKDF2_HMAC(pass, pass_len, salt, salt_len, iter, evp, out_len, out) == 0) {
|
||||
return luaL_error(L, "PKCS5_PBKDF2_HMAC() failed");
|
||||
return luaL_error(L, ERR_error_string(ERR_get_error(), NULL));
|
||||
}
|
||||
|
||||
lua_pushlstring(L, (char *)out, out_len);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue