diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-01-13 13:28:03 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-01-13 13:28:03 +0000 |
commit | 8139a5cd3934ecbb24f042a758e724b6a1fd24f4 (patch) | |
tree | 6f1234df08972bd803f7ab4973cce5b7ccba7c12 /src/plugins/surbl.c | |
parent | ffc1f2334d5eb0ab1485215bd1933bcc5949b8e5 (diff) | |
download | rspamd-8139a5cd3934ecbb24f042a758e724b6a1fd24f4.tar.gz rspamd-8139a5cd3934ecbb24f042a758e724b6a1fd24f4.zip |
[Feature] Reuse URL tags in SURBL module
Diffstat (limited to 'src/plugins/surbl.c')
-rw-r--r-- | src/plugins/surbl.c | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/src/plugins/surbl.c b/src/plugins/surbl.c index e2fcb4060..16516941a 100644 --- a/src/plugins/surbl.c +++ b/src/plugins/surbl.c @@ -717,6 +717,15 @@ surbl_module_config (struct rspamd_config *cfg) else { surbl_module_ctx->url_expire = DEFAULT_SURBL_URL_EXPIRE; } + + if ((value = + rspamd_config_get_module_opt (cfg, "surbl", "use_tags")) != NULL) { + surbl_module_ctx->use_tags = ucl_obj_toboolean (value); + } + else { + surbl_module_ctx->use_tags = TRUE; + } + if ((value = rspamd_config_get_module_opt (cfg, "surbl", "redirector_connect_timeout")) != NULL) { @@ -1407,6 +1416,87 @@ register_redirector_call (struct rspamd_url *url, struct rspamd_task *task, rule); } +static gboolean +surbl_test_tags (struct rspamd_task *task, struct redirector_param *param, + struct rspamd_url *url) +{ + struct rspamd_url_tag *tag = NULL, *rtag = NULL, *cur; + struct rspamd_url *redirected_url = NULL; + gchar *ftld = NULL; + rspamd_ftok_t tld; + gboolean processed = FALSE; + + if (url->tags) { + tag = g_hash_table_lookup (url->tags, "surbl"); + rtag = g_hash_table_lookup (url->tags, "redirector"); + } + + if (rtag) { + /* This is a redirected URL */ + gint r; + + redirected_url = rspamd_mempool_alloc0 (task->task_pool, + sizeof (*redirected_url)); + r = rspamd_url_parse (redirected_url, (gchar *)rtag->data, + strlen (rtag->data), + task->task_pool); + + if (r == URI_ERRNO_OK) { + if (!g_hash_table_lookup (task->urls, redirected_url)) { + g_hash_table_insert (task->urls, redirected_url, + redirected_url); + redirected_url->phished_url = param->url; + redirected_url->flags |= RSPAMD_URL_FLAG_REDIRECTED; + } + } + else { + redirected_url = NULL; + } + } + + if (tag || redirected_url) { + if (redirected_url) { + tld.begin = redirected_url->tld; + tld.len = redirected_url->tldlen; + } + else { + tld.begin = param->url->tld; + tld.len = param->url->tldlen; + } + + ftld = rspamd_mempool_ftokdup (task->task_pool, &tld); + } + + if (tag) { + /* We know results for this URL */ + + DL_FOREACH (tag, cur) { + rspamd_task_insert_result (task, tag->data, 1, ftld); + } + + processed = TRUE; + } + else if (redirected_url) { + /* Just register surbl call for the redirected url */ + make_surbl_requests (redirected_url, + param->task, + param->suffix, + FALSE, + param->tree); + + if (surbl_module_ctx->redirector_symbol != NULL) { + rspamd_task_insert_result (param->task, + surbl_module_ctx->redirector_symbol, + 1, + ftld); + } + + processed = TRUE; + } + + return processed; +} + static void surbl_tree_url_callback (gpointer key, gpointer value, void *data) { @@ -1425,6 +1515,10 @@ surbl_tree_url_callback (gpointer key, gpointer value, void *data) return; } + if (surbl_module_ctx->use_tags && surbl_test_tags (task, param, url)) { + return; + } + if (surbl_module_ctx->use_redirector && surbl_module_ctx->redirector_tlds) { /* Search in trie */ srch.begin = url->tld; |