aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2013-11-07 22:23:23 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2013-11-07 22:23:23 +0000
commita0a7d49e7ebb2479c807d1de26a6dea27e5db064 (patch)
tree70c21f41617d8035597f1781b5b3169206c979b3
parent99f005462db70fd1d07d1cac838a2f5804790734 (diff)
downloadrspamd-a0a7d49e7ebb2479c807d1de26a6dea27e5db064.tar.gz
rspamd-a0a7d49e7ebb2479c807d1de26a6dea27e5db064.zip
Parse composites in ucl.
-rw-r--r--src/cfg_rcl.c42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/cfg_rcl.c b/src/cfg_rcl.c
index eedcd9ee2..41a1cd8c8 100644
--- a/src/cfg_rcl.c
+++ b/src/cfg_rcl.c
@@ -26,6 +26,7 @@
#include "settings.h"
#include "cfg_file.h"
#include "lua/lua_common.h"
+#include "expressions.h"
#include "classifiers/classifiers.h"
#include "tokenizers/tokenizers.h"
@@ -812,6 +813,41 @@ rspamd_rcl_classifier_handler (struct config_file *cfg, ucl_object_t *obj,
return res;
}
+static gboolean
+rspamd_rcl_composite_handler (struct config_file *cfg, ucl_object_t *obj,
+ gpointer ud, struct rspamd_rcl_section *section, GError **err)
+{
+ ucl_object_t *val;
+ struct expression *expr;
+ struct rspamd_composite *composite;
+ const gchar *composite_name, *composite_expression;
+
+ val = ucl_object_find_key (obj, "name");
+ if (val == NULL || !ucl_object_tostring_safe (val, &composite_name)) {
+ g_set_error (err, CFG_RCL_ERROR, EINVAL, "composite must have a name defined");
+ return FALSE;
+ }
+
+ val = ucl_object_find_key (obj, "expression");
+ if (val == NULL || !ucl_object_tostring_safe (val, &composite_expression)) {
+ g_set_error (err, CFG_RCL_ERROR, EINVAL, "composite must have an expression defined");
+ return FALSE;
+ }
+
+ if ((expr = parse_expression (cfg->cfg_pool, (gchar *)composite_expression)) == NULL) {
+ g_set_error (err, CFG_RCL_ERROR, EINVAL, "cannot parse composite expression: %s", composite_expression);
+ return FALSE;
+ }
+
+ composite = memory_pool_alloc (cfg->cfg_pool, sizeof (struct rspamd_composite));
+ composite->expr = expr;
+ composite->id = g_hash_table_size (cfg->composite_symbols) + 1;
+ g_hash_table_insert (cfg->composite_symbols, (gpointer)composite_name, composite);
+ register_virtual_symbol (&cfg->cache, composite_name, 1);
+
+ return TRUE;
+}
+
/**
* Fake handler to parse default options only, uses struct cfg_file as pointer
* for default handlers
@@ -989,6 +1025,12 @@ rspamd_rcl_config_init (void)
rspamd_rcl_add_default_handler (ssub, "spam", rspamd_rcl_parse_struct_boolean,
G_STRUCT_OFFSET (struct statfile, is_spam), 0);
+ /**
+ * Composites handler
+ */
+ sub = rspamd_rcl_add_section (&new, "composite", rspamd_rcl_composite_handler, UCL_OBJECT,
+ FALSE, TRUE);
+
return new;
}