aboutsummaryrefslogtreecommitdiffstats
path: root/src/lua/lua_cryptobox.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-04-23 18:28:27 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-04-23 18:28:27 +0100
commit6b8295c04fb3944dfad38765a9969f3701a88020 (patch)
treec6632243d24830c7443365bdcc92ca7e26f6f602 /src/lua/lua_cryptobox.c
parent2a0301b6b11464f33b4eb63add958a922259f8f1 (diff)
downloadrspamd-6b8295c04fb3944dfad38765a9969f3701a88020.tar.gz
rspamd-6b8295c04fb3944dfad38765a9969f3701a88020.zip
[Minor] Improve IUF interface in cryptobox_hash
Diffstat (limited to 'src/lua/lua_cryptobox.c')
-rw-r--r--src/lua/lua_cryptobox.c62
1 files changed, 41 insertions, 21 deletions
diff --git a/src/lua/lua_cryptobox.c b/src/lua/lua_cryptobox.c
index 1569a9722..c53ffa7f2 100644
--- a/src/lua/lua_cryptobox.c
+++ b/src/lua/lua_cryptobox.c
@@ -33,6 +33,7 @@
#include "libcryptobox/keypair_private.h"
#include "unix-std.h"
#include "contrib/libottery/ottery.h"
+#include "libutil/ref.h"
enum lua_cryptobox_hash_type {
LUA_CRYPTOBOX_HASH_BLAKE2,
@@ -52,6 +53,8 @@ struct rspamd_lua_cryptobox_hash {
unsigned type:7;
unsigned is_finished:1;
+
+ ref_entry_t ref;
};
LUA_FUNCTION_DEF (cryptobox_pubkey, load);
@@ -924,12 +927,35 @@ rspamd_lua_hash_update (struct rspamd_lua_cryptobox_hash *h,
}
}
+static void
+lua_cryptobox_hash_dtor (struct rspamd_lua_cryptobox_hash *h)
+{
+ if (h->type == LUA_CRYPTOBOX_HASH_SSL) {
+#if OPENSSL_VERSION_NUMBER < 0x10100000L || defined(LIBRESSL_VERSION_NUMBER)
+ EVP_MD_CTX_cleanup (h->content.c);
+#else
+ EVP_MD_CTX_reset (h->c);
+#endif
+ EVP_MD_CTX_destroy (h->content.c);
+ }
+ else if (h->type == LUA_CRYPTOBOX_HASH_BLAKE2) {
+ rspamd_explicit_memzero (h->content.h, sizeof (*h->content.h));
+ g_free (h->content.h);
+ }
+ else {
+ g_free (h->content.fh);
+ }
+
+ g_free (h);
+}
+
static struct rspamd_lua_cryptobox_hash *
rspamd_lua_hash_create (const gchar *type)
{
struct rspamd_lua_cryptobox_hash *h;
h = g_malloc0 (sizeof (*h));
+ REF_INIT_RETAIN (h, lua_cryptobox_hash_dtor);
if (type) {
if (g_ascii_strcasecmp (type, "md5") == 0) {
@@ -1155,7 +1181,7 @@ static gint
lua_cryptobox_hash_update (lua_State *L)
{
LUA_TRACE_POINT;
- struct rspamd_lua_cryptobox_hash *h = lua_check_cryptobox_hash (L, 1);
+ struct rspamd_lua_cryptobox_hash *h = lua_check_cryptobox_hash (L, 1), **ph;
const gchar *data;
struct rspamd_lua_text *t;
gsize len;
@@ -1192,7 +1218,12 @@ lua_cryptobox_hash_update (lua_State *L)
return luaL_error (L, "invalid arguments");
}
- return 0;
+ ph = lua_newuserdata (L, sizeof (void *));
+ *ph = h;
+ REF_RETAIN (h);
+ rspamd_lua_setclass (L, "rspamd{cryptobox_hash}", -1);
+
+ return 1;
}
/***
@@ -1203,7 +1234,7 @@ static gint
lua_cryptobox_hash_reset (lua_State *L)
{
LUA_TRACE_POINT;
- struct rspamd_lua_cryptobox_hash *h = lua_check_cryptobox_hash (L, 1);
+ struct rspamd_lua_cryptobox_hash *h = lua_check_cryptobox_hash (L, 1), **ph;
if (h) {
switch (h->type) {
@@ -1239,7 +1270,12 @@ lua_cryptobox_hash_reset (lua_State *L)
return luaL_error (L, "invalid arguments");
}
- return 0;
+ ph = lua_newuserdata (L, sizeof (void *));
+ *ph = h;
+ REF_RETAIN (h);
+ rspamd_lua_setclass (L, "rspamd{cryptobox_hash}", -1);
+
+ return 1;
}
static void
@@ -1388,23 +1424,7 @@ lua_cryptobox_hash_gc (lua_State *L)
LUA_TRACE_POINT;
struct rspamd_lua_cryptobox_hash *h = lua_check_cryptobox_hash (L, 1);
- if (h->type == LUA_CRYPTOBOX_HASH_SSL) {
-#if OPENSSL_VERSION_NUMBER < 0x10100000L || defined(LIBRESSL_VERSION_NUMBER)
- EVP_MD_CTX_cleanup (h->content.c);
-#else
- EVP_MD_CTX_reset (h->c);
-#endif
- EVP_MD_CTX_destroy (h->content.c);
- }
- else if (h->type == LUA_CRYPTOBOX_HASH_BLAKE2) {
- rspamd_explicit_memzero (h->content.h, sizeof (*h->content.h));
- g_free (h->content.h);
- }
- else {
- g_free (h->content.fh);
- }
-
- g_free (h);
+ REF_RELEASE (h);
return 0;
}