summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2020-07-28 14:54:09 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2020-07-28 14:54:09 +0100
commita95c5a23edaddafa96a9c62da4d541abc680b2c5 (patch)
tree8330a624c192563fb58b17bfbf804a7eaef632b3 /src
parent1bf0fb60a13b7bb3fa89f5803bcb1c2f32fa04ff (diff)
downloadrspamd-a95c5a23edaddafa96a9c62da4d541abc680b2c5.tar.gz
rspamd-a95c5a23edaddafa96a9c62da4d541abc680b2c5.zip
[Project] Allow to specify re_conditions for regular expressions
Diffstat (limited to 'src')
-rw-r--r--src/libmime/mime_expressions.c52
1 files changed, 47 insertions, 5 deletions
diff --git a/src/libmime/mime_expressions.c b/src/libmime/mime_expressions.c
index 8f2137d36..aaefd24b3 100644
--- a/src/libmime/mime_expressions.c
+++ b/src/libmime/mime_expressions.c
@@ -807,11 +807,50 @@ set:
mime_atom->d.re = rspamd_mime_expr_parse_regexp_atom (pool,
mime_atom->str, cfg);
if (mime_atom->d.re == NULL) {
- g_set_error (err, rspamd_mime_expr_quark(), 200, "cannot parse regexp '%s'",
+ g_set_error (err, rspamd_mime_expr_quark(), 200,
+ "cannot parse regexp '%s'",
mime_atom->str);
goto err;
}
else {
+ /* Check regexp condition */
+ if (real_ud->conf_obj == NULL) {
+ g_set_error (err, rspamd_mime_expr_quark(), 300,
+ "no config object for '%s'",
+ mime_atom->str);
+ goto err;
+ }
+
+ const ucl_object_t *re_conditions = ucl_object_lookup (real_ud->conf_obj,
+ "re_conditions");
+ gint lua_cbref = -1;
+
+ if (re_conditions != NULL) {
+ if (ucl_object_type (re_conditions) != UCL_OBJECT) {
+ g_set_error (err, rspamd_mime_expr_quark(), 320,
+ "re_conditions is not a table for '%s'",
+ mime_atom->str);
+ goto err;
+ }
+
+ const ucl_object_t *function_obj;
+
+ function_obj = ucl_object_lookup (re_conditions, mime_atom->str);
+
+ if (function_obj != NULL) {
+ if (ucl_object_type (function_obj) != UCL_USERDATA) {
+ g_set_error (err, rspamd_mime_expr_quark(), 320,
+ "condition for '%s' is invalid, must be function",
+ mime_atom->str);
+ goto err;
+ }
+
+ struct ucl_lua_funcdata *fd = function_obj->value.ud;
+
+ lua_cbref = fd->idx;
+ }
+ }
+
/* Register new item in the cache */
if (mime_atom->d.re->type == RSPAMD_RE_HEADER ||
mime_atom->d.re->type == RSPAMD_RE_RAWHEADER ||
@@ -823,7 +862,8 @@ set:
mime_atom->d.re->regexp,
mime_atom->d.re->type,
mime_atom->d.re->extra.header,
- strlen (mime_atom->d.re->extra.header) + 1, -1);
+ strlen (mime_atom->d.re->extra.header) + 1,
+ lua_cbref);
/* Pass ownership to the cache */
rspamd_regexp_unref (own_re);
}
@@ -845,7 +885,8 @@ set:
mime_atom->d.re->regexp,
mime_atom->d.re->type,
mime_atom->d.re->extra.selector,
- strlen (mime_atom->d.re->extra.selector) + 1, -1);
+ strlen (mime_atom->d.re->extra.selector) + 1,
+ lua_cbref);
/* Pass ownership to the cache */
rspamd_regexp_unref (own_re);
}
@@ -866,7 +907,7 @@ set:
mime_atom->d.re->type,
NULL,
0,
- -1);
+ lua_cbref);
/* Pass ownership to the cache */
rspamd_regexp_unref (own_re);
}
@@ -878,7 +919,8 @@ set:
lua_getglobal (cfg->lua_state, mime_atom->str);
if (lua_type (cfg->lua_state, -1) != LUA_TFUNCTION) {
- g_set_error (err, rspamd_mime_expr_quark(), 200, "no such lua function '%s'",
+ g_set_error (err, rspamd_mime_expr_quark(), 200,
+ "no such lua function '%s'",
mime_atom->str);
lua_pop (cfg->lua_state, 1);