aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorIvan Stakhov <50211739+LeftTry@users.noreply.github.com>2024-06-25 17:49:56 +0500
committerGitHub <noreply@github.com>2024-06-25 13:49:56 +0100
commitec1b9b8affaa66dd78f25f712040b3a1bb62fc39 (patch)
treef0d3659a7e57a7044e8247ee2cfefac13b0cd59f
parent1995012959e219e02aef939f9fd3765ffd718e04 (diff)
downloadrspamd-ec1b9b8affaa66dd78f25f712040b3a1bb62fc39.tar.gz
rspamd-ec1b9b8affaa66dd78f25f712040b3a1bb62fc39.zip
Fixed bug with task:inject() function according to the issue #5010 (#5021)
* [Fix] Fix issue with task:inject_url * [Minor] Code clean up * [Minor] Clean up * [Minor] Small fix * [Minor] Fix small typo * [Test] Debug * [Test] Debug * [Test] Debug inject_url * [Test] Debugging * [Test] Debugging task:inject test * [Test] Debugging task:inject test * [Test] Debugging task:inject test * [Minor] Debug task:inject_url test * [Minor] Small fix * [Minor] Debug task:inject_url test * [Test] Test base task:inject * [Test] Test updated task:inject * [Test] Test updated task:inject * [Test] Test updated task:inject * [Test] Test updated task:inject * [Test] Test updated task:inject * [Test] Test fixed task:inject * [Test] Test fixed task:inject * [Test] Testing task:inject * [Test] Testing task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Test base task:inject * [Test] Test base task:inject * [Test] Test base task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Test] Fix task:inject * [Minor] Clean up code in task:inject * [Minor] Updated test for task:inject * [Test] Debug test for task:inject_url * [Test] Debug test for task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Fix task:inject_url * [Test] Check task:inject_url * [Test] Check task:inject_url * [Test] Check task:inject_url * [Test] Check task:inject_url * [Test] Check task:inject_url * [Test] Check task:inject_url * [Minor] Clean up code * [Minor] Clean up code * [Minor] Little fix for error messages in url.create function * [Test] Change way to inject url * [Test] Fix inject url * [Test] Fix inject url * [Test] Fix inject url * [Test] Fix inject url * [Test] Fix inject url * [Minor] Clean up code * [Test] Without fake mime_part * [Test] Without fake mime_part * [Minor] Clean up * [Test] Mime part of the task * [Test] Mpart should exist * [Test] Mpart should exist * [Test] Mpart should exist * [Test] Another check for mpart->urls * [Minor] Clean up * [Minor] Clean up * [Fix] Fixing OpenSSL 3.0 compatibility * [Fix] Reverted
-rw-r--r--src/lua/lua_task.c57
-rw-r--r--src/lua/lua_url.c12
-rw-r--r--test/functional/cases/001_merged/101_lua.robot7
-rw-r--r--test/functional/configs/merged.conf1
-rw-r--r--test/functional/lua/inject_url.lua17
5 files changed, 82 insertions, 12 deletions
diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c
index edbe5b89a..dc41d4ab7 100644
--- a/src/lua/lua_task.c
+++ b/src/lua/lua_task.c
@@ -2634,6 +2634,53 @@ lua_task_has_urls(lua_State *L)
return 2;
}
+struct rspamd_url_query_to_inject_cbd {
+ struct rspamd_task *task;
+ struct rspamd_url *url;
+ GPtrArray *mpart_urls;
+};
+
+static gboolean
+inject_url_query_callback(struct rspamd_url *url, gsize start_offset,
+ gsize end_offset, gpointer ud)
+{
+ struct rspamd_url_query_to_inject_cbd *cbd =
+ (struct rspamd_url_query_to_inject_cbd *) ud;
+ struct rspamd_task *task;
+
+ task = cbd->task;
+
+ url->flags |= RSPAMD_URL_FLAG_QUERY;
+
+ if (rspamd_url_set_add_or_increase(MESSAGE_FIELD(task, urls), url, false) && cbd->mpart_urls) {
+ g_ptr_array_add(cbd->mpart_urls, url);
+ }
+
+ return TRUE;
+}
+
+static void
+inject_url_query(struct rspamd_task *task, struct rspamd_url *url,
+ GPtrArray *part_urls)
+{
+ if (url->querylen > 0) {
+ struct rspamd_url_query_to_inject_cbd cbd;
+
+ cbd.task = task;
+ cbd.url = url;
+ cbd.mpart_urls = part_urls;
+
+ rspamd_url_find_multiple(task->task_pool,
+ rspamd_url_query_unsafe(url), url->querylen,
+ RSPAMD_URL_FIND_ALL, NULL,
+ inject_url_query_callback, &cbd);
+ }
+
+ if (part_urls) {
+ g_ptr_array_add(part_urls, url);
+ }
+}
+
static int
lua_task_inject_url(lua_State *L)
{
@@ -2644,15 +2691,13 @@ lua_task_inject_url(lua_State *L)
if (lua_isuserdata(L, 3)) {
/* We also have a mime part there */
- mpart = *((struct rspamd_mime_part **) rspamd_lua_check_udata_maybe(L,
- 3, rspamd_mimepart_classname));
+ mpart = *((struct rspamd_mime_part **)
+ rspamd_lua_check_udata_maybe(L, 3, rspamd_mimepart_classname));
}
-
if (task && task->message && url && url->url) {
if (rspamd_url_set_add_or_increase(MESSAGE_FIELD(task, urls), url->url, false)) {
- if (mpart && mpart->urls) {
- /* Also add url to the mime part */
- g_ptr_array_add(mpart->urls, url->url);
+ if(mpart && mpart->urls) {
+ inject_url_query(task, url->url, mpart->urls);
}
}
}
diff --git a/src/lua/lua_url.c b/src/lua/lua_url.c
index 8e6680a91..28c42f9f9 100644
--- a/src/lua/lua_url.c
+++ b/src/lua/lua_url.c
@@ -855,18 +855,20 @@ lua_url_create(lua_State *L)
if (lua_type(L, 1) == LUA_TUSERDATA) {
pool = rspamd_lua_check_mempool(L, 1);
t = lua_check_text_or_string(L, 2);
+ if (t == NULL) {
+ return luaL_error(L, "invalid arguments: string/text is expected as the second argument");
+ }
}
else {
pool = static_lua_url_pool;
t = lua_check_text_or_string(L, 1);
+ if (t == NULL) {
+ return luaL_error(L, "invalid arguments: string/text is expected as the first argument");
+ }
}
if (pool == NULL) {
- return luaL_error(L, "invalid arguments: mempool is expected as the second argument");
- }
-
- if (t == NULL) {
- return luaL_error(L, "invalid arguments: string/text is expected as the first argument");
+ return luaL_error(L, "invalid arguments: mempool is expected as the first argument");
}
rspamd_url_find_single(pool, t->start, t->len, RSPAMD_URL_FIND_ALL,
diff --git a/test/functional/cases/001_merged/101_lua.robot b/test/functional/cases/001_merged/101_lua.robot
index d1a771cb3..2cfc03677 100644
--- a/test/functional/cases/001_merged/101_lua.robot
+++ b/test/functional/cases/001_merged/101_lua.robot
@@ -8,6 +8,7 @@ ${MESSAGE} ${RSPAMD_TESTDIR}/messages/spam_message.eml
${RSPAMD_MAP_MAP} ${RSPAMD_TESTDIR}/configs/maps/map.list
${RSPAMD_RADIX_MAP} ${RSPAMD_TESTDIR}/configs/maps/ip2.list
${RSPAMD_REGEXP_MAP} ${RSPAMD_TESTDIR}/configs/maps/regexp.list
+${URL_ICS} ${RSPAMD_TESTDIR}/messages/ics.eml
*** Test Cases ***
Recipient Parsing Sanity
@@ -47,4 +48,8 @@ Rule conditions
External Maps Simple
Scan File ${MESSAGE} Settings={symbols_enabled = [EXTERNAL_MAP]}
- Expect Symbol With Exact Options EXTERNAL_MAP +hello map \ No newline at end of file
+ Expect Symbol With Exact Options EXTERNAL_MAP +hello map
+
+Task Inject Url
+ Scan File ${URL_ICS} Settings={symbols_enabled = [TEST_INJECT_URL]}
+ Expect Symbol TEST_INJECT_URL \ No newline at end of file
diff --git a/test/functional/configs/merged.conf b/test/functional/configs/merged.conf
index 2b3640048..0ee224ceb 100644
--- a/test/functional/configs/merged.conf
+++ b/test/functional/configs/merged.conf
@@ -10,6 +10,7 @@ lua = "{= env.TESTDIR =}/lua/option_order.lua"
lua = "{= env.TESTDIR =}/lua/recipients.lua"
lua = "{= env.TESTDIR =}/lua/remove_result.lua"
lua = "{= env.TESTDIR =}/lua/tlds.lua"
+lua = "{= env.TESTDIR =}/lua/inject_url.lua"
# 104_get_from
lua = "{= env.TESTDIR =}/lua/get_from.lua"
diff --git a/test/functional/lua/inject_url.lua b/test/functional/lua/inject_url.lua
new file mode 100644
index 000000000..f8764b213
--- /dev/null
+++ b/test/functional/lua/inject_url.lua
@@ -0,0 +1,17 @@
+local url = require('rspamd_url')
+
+local function task_inject_cb (task)
+ local url_text = 'http://example.com?redir=https://another.com'
+ local url_to_inject = url.create(task:get_mempool(), url_text)
+ task:inject_url(url_to_inject)
+ if #(task:get_urls()) == 2 then
+ return true
+ end
+ return false
+end
+
+rspamd_config:register_symbol({
+ name = 'TEST_INJECT_URL',
+ score = 1.0,
+ callback = task_inject_cb
+})