aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/libserver/cfg_file.h5
-rw-r--r--src/lua/lua_common.c35
2 files changed, 35 insertions, 5 deletions
diff --git a/src/libserver/cfg_file.h b/src/libserver/cfg_file.h
index f6b1adad6..5f70ccda8 100644
--- a/src/libserver/cfg_file.h
+++ b/src/libserver/cfg_file.h
@@ -84,8 +84,9 @@ struct rspamd_worker_log_pipe {
* script module list item
*/
struct script_module {
- gchar *name; /**< name of module */
- gchar *path; /**< path to module */
+ gchar *name; /**< name of module */
+ gchar *path; /**< path to module */
+ gchar *digest;
};
/**
diff --git a/src/lua/lua_common.c b/src/lua/lua_common.c
index 689dcd1c4..68373c0a9 100644
--- a/src/lua/lua_common.c
+++ b/src/lua/lua_common.c
@@ -1062,10 +1062,36 @@ rspamd_init_lua_filters (struct rspamd_config *cfg, gboolean force_load)
lua_pushcfunction (L, &rspamd_lua_traceback);
err_idx = lua_gettop (L);
- if (luaL_loadfile (L, module->path) != 0) {
+ gsize fsize;
+ guint8 *data = rspamd_file_xmap (module->path,
+ PROT_READ, &fsize, TRUE);
+ guchar digest[rspamd_cryptobox_HASHBYTES];
+
+ if (data == NULL) {
+ msg_err_config ("cannot mmap %s failed: %s", module->path,
+ strerror (errno));
+
+ lua_settop (L, err_idx - 1); /* Error function */
+
+ rspamd_plugins_table_push_elt (L, "disabled_failed",
+ module->name);
+
+ cur = g_list_next (cur);
+ continue;
+ }
+
+ module->digest = rspamd_mempool_alloc (cfg->cfg_pool,
+ rspamd_cryptobox_HASHBYTES * 2 + 1);
+ rspamd_cryptobox_hash (digest, data, fsize, NULL, 0);
+ rspamd_encode_hex_buf (digest, sizeof (digest),
+ module->digest, rspamd_cryptobox_HASHBYTES * 2 + 1);
+ module->digest[rspamd_cryptobox_HASHBYTES * 2] = '\0';
+
+
+ if (luaL_loadbuffer (L, data, fsize, module->path) != 0) {
msg_err_config ("load of %s failed: %s", module->path,
lua_tostring (L, -1));
- lua_pop (L, 1); /* Error function */
+ lua_settop (L, err_idx - 1); /* Error function */
rspamd_plugins_table_push_elt (L, "disabled_failed",
module->name);
@@ -1094,7 +1120,10 @@ rspamd_init_lua_filters (struct rspamd_config *cfg, gboolean force_load)
}
if (!force_load) {
- msg_info_config ("init lua module %s", module->name);
+ msg_info_config ("init lua module %s from %s; digest: %*s",
+ module->name,
+ module->path,
+ 10, module->digest);
}
lua_pop (L, 1); /* Error function */