diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2013-10-27 21:27:37 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2013-10-27 21:27:37 +0000 |
commit | f4453c68aecb0f09b2cc8faf0abdd119fe7d1dd2 (patch) | |
tree | a0f6a80f9ca6063904f0397223af0c82762e0686 | |
parent | dac24787dff6273cc2b6c1584cb255f6b24a0238 (diff) | |
download | rspamd-f4453c68aecb0f09b2cc8faf0abdd119fe7d1dd2.tar.gz rspamd-f4453c68aecb0f09b2cc8faf0abdd119fe7d1dd2.zip |
Parse modules in ucl.
-rw-r--r-- | src/cfg_rcl.c | 62 | ||||
-rw-r--r-- | src/cfg_xml.c | 51 |
2 files changed, 62 insertions, 51 deletions
diff --git a/src/cfg_rcl.c b/src/cfg_rcl.c index 8cd6d2217..2190f648a 100644 --- a/src/cfg_rcl.c +++ b/src/cfg_rcl.c @@ -616,6 +616,62 @@ rspamd_rcl_lua_handler (struct config_file *cfg, ucl_object_t *obj, return TRUE; } +static gboolean +rspamd_rcl_modules_handler (struct config_file *cfg, ucl_object_t *obj, + gpointer ud, struct rspamd_rcl_section *section, GError **err) +{ + ucl_object_t *val, *cur; + struct stat st; + struct script_module *cur_mod; + glob_t globbuf; + gchar *pattern; + const gchar *data; + size_t len; + guint i; + + val = ucl_object_find_key (obj, "path"); + + LL_FOREACH (val, cur) { + if (ucl_object_tostring_safe (cur, &data)) { + if (stat (data, &st) == -1) { + g_set_error (err, CFG_RCL_ERROR, errno, "cannot stat path %s, %s", data, strerror (errno)); + return FALSE; + } + + /* Handle directory */ + if (S_ISDIR (st.st_mode)) { + globbuf.gl_offs = 0; + len = strlen (data) + sizeof ("*.lua"); + pattern = g_malloc (len); + snprintf (pattern, len, "%s%s", data, "*.lua"); + + if (glob (pattern, GLOB_DOOFFS, NULL, &globbuf) == 0) { + for (i = 0; i < globbuf.gl_pathc; i ++) { + cur_mod = memory_pool_alloc (cfg->cfg_pool, sizeof (struct script_module)); + cur_mod->path = memory_pool_strdup (cfg->cfg_pool, globbuf.gl_pathv[i]); + cfg->script_modules = g_list_prepend (cfg->script_modules, cur_mod); + } + globfree (&globbuf); + g_free (pattern); + } + else { + g_set_error (err, CFG_RCL_ERROR, errno, "glob failed for %s, %s", pattern, strerror (errno)); + g_free (pattern); + return FALSE; + } + } + else { + /* Handle single file */ + cur_mod = memory_pool_alloc (cfg->cfg_pool, sizeof (struct script_module)); + cur_mod->path = memory_pool_strdup (cfg->cfg_pool, data); + cfg->script_modules = g_list_prepend (cfg->script_modules, cur_mod); + } + } + } + + return TRUE; +} + /** * Fake handler to parse default options only, uses struct cfg_file as pointer * for default handlers @@ -769,6 +825,12 @@ rspamd_rcl_config_init (void) sub = rspamd_rcl_add_section (&new, "lua", rspamd_rcl_lua_handler, UCL_STRING, FALSE, TRUE); + /** + * Modules handler + */ + sub = rspamd_rcl_add_section (&new, "modules", rspamd_rcl_modules_handler, UCL_OBJECT, + FALSE, TRUE); + return new; } diff --git a/src/cfg_xml.c b/src/cfg_xml.c index 4e3757bad..7c019acff 100644 --- a/src/cfg_xml.c +++ b/src/cfg_xml.c @@ -754,57 +754,6 @@ process_attrs (const gchar **attribute_names, const gchar **attribute_values, uc /* Handlers */ - - -/* Modules section */ -gboolean -handle_module_path (struct config_file *cfg, struct rspamd_xml_userdata *ctx, GHashTable *attrs, gchar *data, gpointer user_data, gpointer dest_struct, gint offset) -{ - struct stat st; - struct script_module *cur; - glob_t globbuf; - gchar *pattern; - size_t len; - guint i; - - if (stat (data, &st) == -1) { - msg_err ("cannot stat path %s, %s", data, strerror (errno)); - return FALSE; - } - - /* Handle directory */ - if (S_ISDIR (st.st_mode)) { - globbuf.gl_offs = 0; - len = strlen (data) + sizeof ("*.lua"); - pattern = g_malloc (len); - snprintf (pattern, len, "%s%s", data, "*.lua"); - - if (glob (pattern, GLOB_DOOFFS, NULL, &globbuf) == 0) { - for (i = 0; i < globbuf.gl_pathc; i ++) { - cur = memory_pool_alloc (cfg->cfg_pool, sizeof (struct script_module)); - cur->path = memory_pool_strdup (cfg->cfg_pool, globbuf.gl_pathv[i]); - cfg->script_modules = g_list_prepend (cfg->script_modules, cur); - } - globfree (&globbuf); - g_free (pattern); - } - else { - msg_err ("glob failed: %s", strerror (errno)); - g_free (pattern); - return FALSE; - } - } - else { - /* Handle single file */ - cur = memory_pool_alloc (cfg->cfg_pool, sizeof (struct script_module)); - cur->path = memory_pool_strdup (cfg->cfg_pool, data); - cfg->script_modules = g_list_prepend (cfg->script_modules, cur); - } - - - return TRUE; -} - gboolean handle_composite (struct config_file *cfg, struct rspamd_xml_userdata *ctx, GHashTable *attrs, gchar *data, gpointer user_data, gpointer dest_struct, gint offset) { |