summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-12-03 17:37:53 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-12-03 17:37:53 +0000
commitcdf89b1d3b599cdc1716403dcc93f0ca4f06a247 (patch)
tree1bda580c4adfc748907cfc47f618fab38f76e86c
parent45e84668a1c7a7131db53e2b94375cfc98d68556 (diff)
downloadrspamd-cdf89b1d3b599cdc1716403dcc93f0ca4f06a247.tar.gz
rspamd-cdf89b1d3b599cdc1716403dcc93f0ca4f06a247.zip
Fix code for the new cache
-rw-r--r--src/libmime/mime_expressions.c418
-rw-r--r--src/libserver/cfg_utils.c2
-rw-r--r--src/libserver/re_cache.c26
-rw-r--r--src/libserver/re_cache.h5
-rw-r--r--src/libserver/task.c37
-rw-r--r--src/libserver/task.h20
-rw-r--r--src/lua/lua_task.c20
-rw-r--r--src/plugins/regexp.c2
8 files changed, 99 insertions, 431 deletions
diff --git a/src/libmime/mime_expressions.c b/src/libmime/mime_expressions.c
index 0bee87f4c..9218b4a02 100644
--- a/src/libmime/mime_expressions.c
+++ b/src/libmime/mime_expressions.c
@@ -93,22 +93,10 @@ static gint rspamd_mime_expr_priority (rspamd_expression_atom_t *atom);
static void rspamd_mime_expr_destroy (rspamd_expression_atom_t *atom);
/**
- * Regexp type: /H - header, /M - mime, /U - url /X - raw header
- */
-enum rspamd_regexp_type {
- REGEXP_NONE = 0,
- REGEXP_HEADER,
- REGEXP_MIME,
- REGEXP_MESSAGE,
- REGEXP_URL,
- REGEXP_RAW_HEADER
-};
-
-/**
* Regexp structure
*/
struct rspamd_regexp_atom {
- enum rspamd_regexp_type type; /**< regexp type */
+ enum rspamd_re_type type; /**< regexp type */
gchar *regexp_text; /**< regexp text representation */
rspamd_regexp_t *regexp; /**< regexp structure */
gchar *header; /**< header name for header regexps */
@@ -181,7 +169,6 @@ static struct _fl *list_ptr = &rspamd_functions_list[0];
static guint32 functions_number = sizeof (rspamd_functions_list) /
sizeof (struct _fl);
static gboolean list_allocated = FALSE;
-static guint max_re_data = 0;
/* Bsearch routine */
static gint
@@ -246,13 +233,13 @@ rspamd_mime_expr_parse_regexp_atom (rspamd_mempool_t * pool, const gchar *line)
if (end) {
result->header = rspamd_mempool_alloc (pool, end - line + 1);
rspamd_strlcpy (result->header, line, end - line + 1);
- result->type = REGEXP_HEADER;
+ result->type = RSPAMD_RE_HEADER;
line = end;
}
}
else {
result->header = rspamd_mempool_strdup (pool, line);
- result->type = REGEXP_HEADER;
+ result->type = RSPAMD_RE_HEADER;
line = start;
}
/* Find begin of regexp */
@@ -265,7 +252,7 @@ rspamd_mime_expr_parse_regexp_atom (rspamd_mempool_t * pool, const gchar *line)
else if (result->header == NULL) {
/* Assume that line without // is just a header name */
result->header = rspamd_mempool_strdup (pool, line);
- result->type = REGEXP_HEADER;
+ result->type = RSPAMD_RE_HEADER;
return result;
}
else {
@@ -304,33 +291,23 @@ rspamd_mime_expr_parse_regexp_atom (rspamd_mempool_t * pool, const gchar *line)
break;
/* Type flags */
case 'H':
- if (result->type == REGEXP_NONE) {
- result->type = REGEXP_HEADER;
- }
+ result->type = RSPAMD_RE_HEADER;
p++;
break;
case 'M':
- if (result->type == REGEXP_NONE) {
- result->type = REGEXP_MESSAGE;
- }
+ result->type = RSPAMD_RE_BODY;
p++;
break;
case 'P':
- if (result->type == REGEXP_NONE) {
- result->type = REGEXP_MIME;
- }
+ result->type = RSPAMD_RE_MIME;
p++;
break;
case 'U':
- if (result->type == REGEXP_NONE) {
- result->type = REGEXP_URL;
- }
+ result->type = RSPAMD_RE_URL;
p++;
break;
case 'X':
- if (result->type == REGEXP_NONE || result->type == REGEXP_HEADER) {
- result->type = REGEXP_RAW_HEADER;
- }
+ result->type = RSPAMD_RE_RAWHEADER;
p++;
break;
case 'T':
@@ -634,6 +611,19 @@ set:
mime_atom->str);
goto err;
}
+ else {
+ /* Register new item in the cache */
+ if (mime_atom->d.re->type == RSPAMD_RE_HEADER ||
+ mime_atom->d.re->type == RSPAMD_RE_RAWHEADER) {
+ rspamd_re_cache_add (cfg->re_cache, mime_atom->d.re->regexp,
+ mime_atom->d.re->type, mime_atom->d.re->header,
+ strlen (mime_atom->d.re->header));
+ }
+ else {
+ rspamd_re_cache_add (cfg->re_cache, mime_atom->d.re->regexp,
+ mime_atom->d.re->type, NULL, 0);
+ }
+ }
}
else if (type == MIME_ATOM_LUA_FUNCTION) {
mime_atom->d.lua_function = mime_atom->str;
@@ -674,292 +664,42 @@ err:
return NULL;
}
-static const gchar *
-rspamd_mime_regexp_type_to_string (struct rspamd_regexp_atom *re)
-{
- const gchar *ret = "unknown";
-
- switch (re->type) {
- case REGEXP_NONE:
- ret = "none";
- break;
- case REGEXP_HEADER:
- ret = "header";
- break;
- case REGEXP_RAW_HEADER:
- ret = "raw header";
- break;
- case REGEXP_MIME:
- ret = "part";
- break;
- case REGEXP_MESSAGE:
- ret = "message";
- break;
- case REGEXP_URL:
- ret = "url";
- break;
- }
-
- return ret;
-}
-
-static gint
-rspamd_mime_regexp_element_process (struct rspamd_task *task,
- struct rspamd_regexp_atom *re, const gchar *data, gsize len,
- gboolean raw)
-{
- guint r = 0;
- const gchar *start = NULL, *end = NULL;
-
- if ((r = rspamd_task_re_cache_check (task, re->regexp_text)) !=
- RSPAMD_TASK_CACHE_NO_VALUE) {
- debug_task ("%s regexp %s is found in cache, result: %d",
- rspamd_mime_regexp_type_to_string (re), re->regexp_text, r);
- return r;
- }
-
- /*
- * Since we've queried cache for the value
- * r could be RSPAMD_TASK_CACHE_NO_VALUE. Hence, we need to reset it here
- * to avoid suspicious results
- */
- r = 0;
- if (len == 0) {
- len = strlen (data);
- }
-
- if (max_re_data > 0 && len > max_re_data) {
- len = max_re_data;
- }
-
- while (rspamd_regexp_search (re->regexp, data, len, &start, &end, raw, NULL)) {
- r++;
-
- if (!re->is_multiple) {
- break;
- }
- }
-
- if (G_UNLIKELY (re->is_test)) {
- msg_info_task (
- "process %s test regexp %s returned %d",
- rspamd_mime_regexp_type_to_string (re),
- re->regexp_text,
- r);
- }
-
- return r;
-}
-
-struct url_regexp_param {
- struct rspamd_task *task;
- rspamd_regexp_t *regexp;
- struct rspamd_regexp_atom *re;
- gint found;
-};
-
-static void
-tree_url_callback (gpointer key, gpointer value, void *data)
-{
- struct url_regexp_param *param = data;
- struct rspamd_url *url = value;
- struct rspamd_task *task;
- gint ret;
-
- if (param->found && ! param->re->is_multiple) {
- return;
- }
-
- task = param->task;
- ret = rspamd_mime_regexp_element_process (param->task, param->re,
- url->string, url->urllen, FALSE);
-
- param->found = ret;
-
- if (G_UNLIKELY (param->re->is_test)) {
- msg_info_task ("process test regexp %s for url %*s returned FALSE",
- param->re->regexp_text, url->urllen, url->string);
- }
-}
-
static gint
rspamd_mime_expr_process_regexp (struct rspamd_regexp_atom *re,
struct rspamd_task *task)
{
- guint8 *ct;
- gsize clen;
- gboolean raw = FALSE;
- const gchar *in;
- gint ret = 0;
- GList *cur, *headerlist;
- guint i;
- rspamd_regexp_t *regexp;
- struct url_regexp_param callback_param = {
- .task = task,
- .re = re,
- .found = FALSE
- };
- struct mime_text_part *part;
- struct raw_header *rh;
+ gint ret;
if (re == NULL) {
msg_info_task ("invalid regexp passed");
return 0;
}
- callback_param.regexp = re->regexp;
-
-
- switch (re->type) {
- case REGEXP_NONE:
- msg_warn_task ("bad error detected: %s has invalid regexp type",
- re->regexp_text);
- break;
- case REGEXP_HEADER:
- case REGEXP_RAW_HEADER:
- /* Check header's name */
- if (re->header == NULL) {
- msg_info_task ("header regexp without header name: '%s'",
- re->regexp_text);
- rspamd_task_re_cache_add (task, re->regexp_text, 0);
- return 0;
- }
- debug_task ("checking %s header regexp: %s = %s",
- re->type == REGEXP_RAW_HEADER ? "raw" : "decoded",
- re->header,
- re->regexp_text);
-
- /* Get list of specified headers */
- headerlist = rspamd_message_get_header (task,
+ if (re->type == RSPAMD_RE_HEADER || re->type == RSPAMD_RE_RAWHEADER) {
+ ret = rspamd_re_cache_process (task,
+ task->re_rt,
+ re->regexp,
+ re->type,
re->header,
- re->is_strong);
- if (headerlist == NULL) {
- /* Header is not found */
- if (G_UNLIKELY (re->is_test)) {
- msg_info_task (
- "process test regexp %s for header %s returned FALSE: no header found",
- re->regexp_text,
- re->header);
- }
- }
- else {
- /* Check whether we have regexp for it */
- if (re->regexp == NULL) {
- debug_task ("regexp contains only header and it is found %s",
- re->header);
- rspamd_task_re_cache_add (task, re->regexp_text, 1);
- ret = 1;
- }
- else {
- /* Iterate through headers */
- cur = headerlist;
- while (cur) {
- rh = cur->data;
- debug_task ("found header \"%s\" with value \"%s\"",
- re->header, rh->decoded);
- regexp = re->regexp;
-
- if (re->type == REGEXP_RAW_HEADER) {
- in = rh->value;
- raw = TRUE;
- }
- else {
- in = rh->decoded;
- /* Validate input */
- if (!in || !g_utf8_validate (in, -1, NULL)) {
- cur = g_list_next (cur);
- continue;
- }
- }
-
- /* Match re */
- if (in) {
- ret += rspamd_mime_regexp_element_process (task, re, in,
- strlen (in), raw);
- debug_task ("checking header %s regexp: %s -> %d",
- re->header, re->regexp_text, ret);
-
- if (!re->is_multiple && ret) {
- break;
- }
- }
-
- cur = g_list_next (cur);
- }
- }
- }
- break;
- case REGEXP_MIME:
- /* Iterate throught text parts */
- for (i = 0; i < task->text_parts->len; i ++) {
- part = g_ptr_array_index (task->text_parts, i);
-
- /* Skip empty parts */
- if (IS_PART_EMPTY (part)) {
- continue;
- }
-
- /* Check raw flags */
- if (!IS_PART_UTF (part)) {
- raw = TRUE;
- }
- /* Select data for regexp */
- if (raw) {
- ct = part->orig->data;
- clen = part->orig->len;
- }
- else {
- ct = part->content->data;
- clen = part->content->len;
- }
- /* If we have limit, apply regexp so much times as we can */
- ret = rspamd_mime_regexp_element_process (task, re, ct, clen, raw);
- debug_task ("checking mime regexp: %s -> %d",
- re->regexp_text, ret);
-
- if (!re->is_multiple && ret) {
- break;
- }
- }
-
- break;
- case REGEXP_MESSAGE:
- raw = TRUE;
- ct = (guint8 *)task->msg.begin;
- clen = task->msg.len;
-
- ret = rspamd_mime_regexp_element_process (task, re, ct, clen, raw);
- break;
- case REGEXP_URL:
- debug_task ("checking url regexp: %s", re->regexp_text);
- regexp = re->regexp;
- callback_param.task = task;
- callback_param.regexp = regexp;
- callback_param.re = re;
- callback_param.found = 0;
-
- if (task->urls) {
- g_hash_table_foreach (task->urls, tree_url_callback, &callback_param);
- }
-
- if (task->emails && !callback_param.found) {
- g_hash_table_foreach (task->emails, tree_url_callback, &callback_param);
- }
-
- ret = callback_param.found;
- break;
- default:
- msg_warn_task ("bad error detected: %p is not a valid regexp object", re);
- return 0;
- break;
+ strlen (re->header),
+ re->is_strong,
+ re->is_multiple);
+ }
+ else {
+ ret = rspamd_re_cache_process (task,
+ task->re_rt,
+ re->regexp,
+ re->type,
+ NULL,
+ 0,
+ re->is_strong,
+ re->is_multiple);
}
- if (re && re->regexp_text) {
- if (ret > 1 && !re->is_multiple) {
- ret = 1;
- }
-
- rspamd_task_re_cache_add (task, re->regexp_text, ret);
+ if (re->is_test) {
+ msg_info_task ("test %s regexp '%s' returned %d",
+ rspamd_re_cache_type_to_string (re->type),
+ re->regexp_text, ret);
}
return ret;
@@ -982,14 +722,14 @@ rspamd_mime_expr_priority (rspamd_expression_atom_t *atom)
break;
case MIME_ATOM_REGEXP:
switch (mime_atom->d.re->type) {
- case REGEXP_HEADER:
- case REGEXP_RAW_HEADER:
+ case RSPAMD_RE_HEADER:
+ case RSPAMD_RE_RAWHEADER:
ret = 100;
break;
- case REGEXP_URL:
+ case RSPAMD_RE_URL:
ret = 90;
break;
- case REGEXP_MIME:
+ case RSPAMD_RE_MIME:
ret = 10;
break;
default:
@@ -1651,11 +1391,9 @@ match_smtp_data (struct rspamd_task *task,
return FALSE;
}
- if ((r = rspamd_task_re_cache_check (task,
- rspamd_regexp_get_pattern (re))) == -1) {
- r = rspamd_regexp_search (re, what, 0, NULL, NULL, FALSE, NULL);
- rspamd_task_re_cache_add (task, rspamd_regexp_get_pattern (re), r);
- }
+
+ r = rspamd_regexp_search (re, what, 0, NULL, NULL, FALSE, NULL);
+
return r;
}
else if (arg->type == EXPRESSION_ARGUMENT_NORMAL &&
@@ -1838,14 +1576,8 @@ rspamd_content_type_compare_param (struct rspamd_task * task,
else {
if (arg_pattern->type == EXPRESSION_ARGUMENT_REGEXP) {
re = arg_pattern->data;
-
- if ((r = rspamd_task_re_cache_check (task,
- rspamd_regexp_get_pattern (re))) == -1) {
- r = rspamd_regexp_search (re, param_data, 0,
+ r = rspamd_regexp_search (re, param_data, 0,
NULL, NULL, FALSE, NULL);
- rspamd_task_re_cache_add (task,
- rspamd_regexp_get_pattern (re), r);
- }
}
else {
/* Just do strcasecmp */
@@ -1981,14 +1713,8 @@ rspamd_content_type_check (struct rspamd_task *task,
if (arg_pattern->type == EXPRESSION_ARGUMENT_REGEXP) {
re = arg_pattern->data;
-
- if ((r = rspamd_task_re_cache_check (task,
- rspamd_regexp_get_pattern (re))) == -1) {
- r = rspamd_regexp_search (re, param_data, 0,
- NULL, NULL, FALSE, NULL);
- rspamd_task_re_cache_add (task,
- rspamd_regexp_get_pattern (re), r);
- }
+ r = rspamd_regexp_search (re, param_data, 0,
+ NULL, NULL, FALSE, NULL);
}
else {
/* Just do strcasecmp */
@@ -2035,14 +1761,8 @@ compare_subtype (struct rspamd_task *task, GMimeContentType * ct,
}
if (subtype->type == EXPRESSION_ARGUMENT_REGEXP) {
re = subtype->data;
-
- if ((r = rspamd_task_re_cache_check (task,
- rspamd_regexp_get_pattern (re))) == -1) {
- r = rspamd_regexp_search (re, ct->subtype, 0,
- NULL, NULL, FALSE, NULL);
- rspamd_task_re_cache_add (task,
- rspamd_regexp_get_pattern (re), r);
- }
+ r = rspamd_regexp_search (re, ct->subtype, 0,
+ NULL, NULL, FALSE, NULL);
}
else {
/* Just do strcasecmp */
@@ -2096,17 +1816,12 @@ common_has_content_part (struct rspamd_task * task,
if (param_type->type == EXPRESSION_ARGUMENT_REGEXP) {
re = param_type->data;
- if ((r = rspamd_task_re_cache_check (task,
- rspamd_regexp_get_pattern (re))) == -1) {
- r = rspamd_regexp_search (re, ct->type, 0,
- NULL, NULL, FALSE, NULL);
- /* Also check subtype and length of the part */
- if (r && param_subtype) {
- r = compare_len (part, min_len, max_len) &&
+ r = rspamd_regexp_search (re, ct->type, 0,
+ NULL, NULL, FALSE, NULL);
+ /* Also check subtype and length of the part */
+ if (r && param_subtype) {
+ r = compare_len (part, min_len, max_len) &&
compare_subtype (task, ct, param_subtype);
- }
- rspamd_task_re_cache_add (task,
- rspamd_regexp_get_pattern (re), r);
}
}
else {
@@ -2198,12 +1913,3 @@ rspamd_has_content_part_len (struct rspamd_task * task,
return common_has_content_part (task, param_type, param_subtype, min, max);
}
-
-guint
-rspamd_mime_expression_set_re_limit (guint limit)
-{
- guint ret = max_re_data;
-
- max_re_data = limit;
- return ret;
-}
diff --git a/src/libserver/cfg_utils.c b/src/libserver/cfg_utils.c
index 2d185a59d..8c7164fd0 100644
--- a/src/libserver/cfg_utils.c
+++ b/src/libserver/cfg_utils.c
@@ -198,7 +198,7 @@ rspamd_config_new (void)
cfg->lua_state = rspamd_lua_init (cfg);
cfg->cache = rspamd_symbols_cache_new (cfg);
cfg->ups_ctx = rspamd_upstreams_library_init ();
- cfg->re_cache = rspamd_regexp_cache_new ();
+ cfg->re_cache = rspamd_re_cache_new ();
REF_INIT_RETAIN (cfg, rspamd_config_free);
diff --git a/src/libserver/re_cache.c b/src/libserver/re_cache.c
index 5ec8dd0aa..40428b6f1 100644
--- a/src/libserver/re_cache.c
+++ b/src/libserver/re_cache.c
@@ -473,3 +473,29 @@ rspamd_re_cache_set_limit (struct rspamd_re_cache *cache, guint limit)
return old;
}
+
+const gchar *
+rspamd_re_cache_type_to_string (enum rspamd_re_type type)
+{
+ const gchar *ret = "unknown";
+
+ switch (type) {
+ case RSPAMD_RE_HEADER:
+ ret = "header";
+ break;
+ case RSPAMD_RE_RAWHEADER:
+ ret = "raw header";
+ break;
+ case RSPAMD_RE_MIME:
+ ret = "part";
+ break;
+ case RSPAMD_RE_BODY:
+ ret = "rawbody";
+ break;
+ case RSPAMD_RE_URL:
+ ret = "url";
+ break;
+ }
+
+ return ret;
+}
diff --git a/src/libserver/re_cache.h b/src/libserver/re_cache.h
index ae23fc89a..4fa3fc286 100644
--- a/src/libserver/re_cache.h
+++ b/src/libserver/re_cache.h
@@ -104,4 +104,9 @@ struct rspamd_re_cache *rspamd_re_cache_ref (struct rspamd_re_cache *cache);
*/
guint rspamd_re_cache_set_limit (struct rspamd_re_cache *cache, guint limit);
+/**
+ * Convert re type to a human readable string (constant one)
+ */
+const gchar * rspamd_re_cache_type_to_string (enum rspamd_re_type type);
+
#endif
diff --git a/src/libserver/task.c b/src/libserver/task.c
index 2f4d7ad89..31370a6eb 100644
--- a/src/libserver/task.c
+++ b/src/libserver/task.c
@@ -602,43 +602,6 @@ rspamd_task_add_sender (struct rspamd_task *task, const gchar *sender)
return FALSE;
}
-
-guint
-rspamd_task_re_cache_add (struct rspamd_task *task, const gchar *re,
- guint value)
-{
- guint ret = RSPAMD_TASK_CACHE_NO_VALUE;
- static const guint32 mask = 1 << 31;
- gpointer p;
-
- p = g_hash_table_lookup (task->re_cache, re);
-
- if (p != NULL) {
- ret = GPOINTER_TO_INT (p) & ~mask;
- }
-
- g_hash_table_insert (task->re_cache, (gpointer)re,
- GINT_TO_POINTER (value | mask));
-
- return ret;
-}
-
-guint
-rspamd_task_re_cache_check (struct rspamd_task *task, const gchar *re)
-{
- guint ret = RSPAMD_TASK_CACHE_NO_VALUE;
- static const guint32 mask = 1 << 31;
- gpointer p;
-
- p = g_hash_table_lookup (task->re_cache, re);
-
- if (p != NULL) {
- ret = GPOINTER_TO_INT (p) & ~mask;
- }
-
- return ret;
-}
-
gboolean
rspamd_learn_task_spam (struct rspamd_task *task,
gboolean is_spam,
diff --git a/src/libserver/task.h b/src/libserver/task.h
index 21d885b25..2047d701c 100644
--- a/src/libserver/task.h
+++ b/src/libserver/task.h
@@ -239,26 +239,6 @@ gboolean rspamd_task_add_recipient (struct rspamd_task *task, const gchar *rcpt)
*/
gboolean rspamd_task_add_sender (struct rspamd_task *task, const gchar *sender);
-#define RSPAMD_TASK_CACHE_NO_VALUE ((guint)-1)
-
-/**
- * Add or replace the value to the task cache of regular expressions results
- * @param task task object
- * @param re text value of regexp
- * @param value value to add
- * @return previous value of element or RSPAMD_TASK_CACHE_NO_VALUE
- */
-guint rspamd_task_re_cache_add (struct rspamd_task *task, const gchar *re,
- guint value);
-
-/**
- * Check for cached result of re inside cache
- * @param task task object
- * @param re text value of regexp
- * @return the current value of element or RSPAMD_TASK_CACHE_NO_VALUE
- */
-guint rspamd_task_re_cache_check (struct rspamd_task *task, const gchar *re);
-
/**
* Learn specified statfile with message in a task
* @param task worker's task object
diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c
index 69644ba24..c10cfe72b 100644
--- a/src/lua/lua_task.c
+++ b/src/lua/lua_task.c
@@ -1986,14 +1986,9 @@ static gint
lua_task_cache_get (lua_State *L)
{
struct rspamd_task *task = lua_check_task (L, 1);
- const gchar *k = luaL_checkstring (L, 2);
- gint res = RSPAMD_TASK_CACHE_NO_VALUE;
- if (task && k) {
- res = rspamd_task_re_cache_check (task, k);
- }
-
- lua_pushnumber (L, res);
+ msg_err_task ("this function is deprecated and will return nothing");
+ lua_pushnumber (L, -1);
return 1;
}
@@ -2002,16 +1997,9 @@ static gint
lua_task_cache_set (lua_State *L)
{
struct rspamd_task *task = lua_check_task (L, 1);
- const gchar *k = luaL_checkstring (L, 2);
- gint res = RSPAMD_TASK_CACHE_NO_VALUE, param = RSPAMD_TASK_CACHE_NO_VALUE;;
-
- param = lua_tonumber (L, 3);
- if (task && k && param >= 0) {
- res = rspamd_task_re_cache_check (task, k);
- rspamd_task_re_cache_add (task, k, param);
- }
- lua_pushnumber (L, res);
+ msg_err_task ("this function is deprecated and will return nothing");
+ lua_pushnumber (L, 0);
return 1;
}
diff --git a/src/plugins/regexp.c b/src/plugins/regexp.c
index 08c38ffb9..efee83e35 100644
--- a/src/plugins/regexp.c
+++ b/src/plugins/regexp.c
@@ -129,7 +129,7 @@ regexp_module_config (struct rspamd_config *cfg)
if (g_ascii_strncasecmp (ucl_object_key (value), "max_size",
sizeof ("max_size") - 1) == 0) {
regexp_module_ctx->max_size = ucl_obj_toint (value);
- rspamd_mime_expression_set_re_limit (regexp_module_ctx->max_size);
+ rspamd_re_cache_set_limit (cfg->re_cache, regexp_module_ctx->max_size);
}
else if (g_ascii_strncasecmp (ucl_object_key (value), "max_threads",
sizeof ("max_threads") - 1) == 0) {