aboutsummaryrefslogtreecommitdiffstats
path: root/src/lua/lua_task.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lua/lua_task.c')
-rw-r--r--src/lua/lua_task.c106
1 files changed, 54 insertions, 52 deletions
diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c
index 351dd9208..427314745 100644
--- a/src/lua/lua_task.c
+++ b/src/lua/lua_task.c
@@ -3352,7 +3352,7 @@ enum lua_email_address_type {
* for get_from/get_recipients
*/
static enum lua_email_address_type
-lua_task_str_to_get_type(lua_State *L, struct rspamd_task *task, gint pos)
+lua_task_str_to_get_type(lua_State *L, struct rspamd_task *task, gint pos, gint last_pos)
{
const gchar *type = NULL;
gint ret = LUA_ADDRESS_ANY;
@@ -3360,43 +3360,18 @@ lua_task_str_to_get_type(lua_State *L, struct rspamd_task *task, gint pos)
gsize sz;
/* Get what value */
+ do {
+ if (lua_type(L, pos) == LUA_TNUMBER) {
+ ret = lua_tonumber(L, pos);
- if (lua_type(L, pos) == LUA_TNUMBER) {
- ret = lua_tonumber(L, pos);
-
- if (ret >= LUA_ADDRESS_ANY && ret < LUA_ADDRESS_MAX) {
- return ret;
- }
-
- return LUA_ADDRESS_ANY;
- }
- else if (lua_type(L, pos) == LUA_TSTRING) {
- type = lua_tolstring(L, pos, &sz);
-
- if (type && sz > 0) {
- h = rspamd_cryptobox_fast_hash_specific(RSPAMD_CRYPTOBOX_XXHASH64,
- type, sz, 0xdeadbabe);
-
- switch (h) {
- case 0xDA081341FB600389ULL: /* mime */
- ret = LUA_ADDRESS_MIME;
- break;
- case 0xEEC8A7832F8C43ACULL: /* any */
- ret = LUA_ADDRESS_ANY;
- break;
- case 0x472274D5193B2A80ULL: /* smtp */
- case 0xEFE0F586CC9F14A9ULL: /* envelope */
- ret = LUA_ADDRESS_SMTP;
- break;
- default:
- msg_err_task("invalid email type: %*s", (gint) sz, type);
- break;
+ if (ret >= LUA_ADDRESS_ANY && ret < LUA_ADDRESS_MAX) {
+ return ret;
}
+
+ return LUA_ADDRESS_ANY;
}
- }
- else if (lua_type(L, pos) == LUA_TTABLE) {
- for (lua_pushnil(L); lua_next(L, pos); lua_pop(L, 1)) {
- type = lua_tolstring(L, -1, &sz);
+ else if (lua_type(L, pos) == LUA_TSTRING) {
+ type = lua_tolstring(L, pos, &sz);
if (type && sz > 0) {
h = rspamd_cryptobox_fast_hash_specific(RSPAMD_CRYPTOBOX_XXHASH64,
@@ -3404,21 +3379,14 @@ lua_task_str_to_get_type(lua_State *L, struct rspamd_task *task, gint pos)
switch (h) {
case 0xDA081341FB600389ULL: /* mime */
- ret |= LUA_ADDRESS_MIME;
+ ret = LUA_ADDRESS_MIME;
break;
case 0xEEC8A7832F8C43ACULL: /* any */
- ret |= LUA_ADDRESS_ANY;
+ ret = LUA_ADDRESS_ANY;
break;
case 0x472274D5193B2A80ULL: /* smtp */
case 0xEFE0F586CC9F14A9ULL: /* envelope */
- ret |= LUA_ADDRESS_SMTP;
- break;
- case 0xAF4DE083D9AD0132: /* raw */
- ret |= LUA_ADDRESS_RAW;
- break;
- case 0xC7AB6C7B7B0F5A8A: /* orig */
- case 0x1778AE905589E431: /* original */
- ret |= LUA_ADDRESS_ORIGINAL;
+ ret = LUA_ADDRESS_SMTP;
break;
default:
msg_err_task("invalid email type: %*s", (gint) sz, type);
@@ -3426,7 +3394,41 @@ lua_task_str_to_get_type(lua_State *L, struct rspamd_task *task, gint pos)
}
}
}
- }
+ else if (lua_type(L, pos) == LUA_TTABLE) {
+ for (lua_pushnil(L); lua_next(L, pos); lua_pop(L, 1)) {
+ type = lua_tolstring(L, -1, &sz);
+
+ if (type && sz > 0) {
+ h = rspamd_cryptobox_fast_hash_specific(RSPAMD_CRYPTOBOX_XXHASH64,
+ type, sz, 0xdeadbabe);
+
+ switch (h) {
+ case 0xDA081341FB600389ULL: /* mime */
+ ret |= LUA_ADDRESS_MIME;
+ break;
+ case 0xEEC8A7832F8C43ACULL: /* any */
+ ret |= LUA_ADDRESS_ANY;
+ break;
+ case 0x472274D5193B2A80ULL: /* smtp */
+ case 0xEFE0F586CC9F14A9ULL: /* envelope */
+ ret |= LUA_ADDRESS_SMTP;
+ break;
+ case 0xAF4DE083D9AD0132: /* raw */
+ ret |= LUA_ADDRESS_RAW;
+ break;
+ case 0xC7AB6C7B7B0F5A8A: /* orig */
+ case 0x1778AE905589E431: /* original */
+ ret |= LUA_ADDRESS_ORIGINAL;
+ break;
+ default:
+ msg_err_task("invalid email type: %*s", (gint) sz, type);
+ break;
+ }
+ }
+ }
+ }
+ pos++;
+ } while (pos <= last_pos);
return ret;
}
@@ -3666,7 +3668,7 @@ lua_task_get_recipients(lua_State *L)
if (task) {
if (lua_gettop(L) == 2) {
/* Get what value */
- what = lua_task_str_to_get_type(L, task, 2);
+ what = lua_task_str_to_get_type(L, task, 2, lua_gettop(L));
}
switch (what & LUA_ADDRESS_MASK) {
@@ -3716,7 +3718,7 @@ lua_task_set_recipients(lua_State *L)
if (task && lua_gettop(L) >= 3) {
/* Get what value */
- what = lua_task_str_to_get_type(L, task, 2);
+ what = lua_task_str_to_get_type(L, task, 2, -1);
if (lua_isstring(L, 4)) {
how = lua_tostring(L, 4);
@@ -3839,7 +3841,7 @@ lua_task_has_from(lua_State *L)
if (task) {
if (lua_gettop(L) == 2) {
/* Get what value */
- what = lua_task_str_to_get_type(L, task, 2);
+ what = lua_task_str_to_get_type(L, task, 2, lua_gettop(L));
}
switch (what & LUA_ADDRESS_MASK) {
@@ -3898,7 +3900,7 @@ lua_task_has_recipients(lua_State *L)
if (task) {
if (lua_gettop(L) == 2) {
/* Get what value */
- what = lua_task_str_to_get_type(L, task, 2);
+ what = lua_task_str_to_get_type(L, task, 2, lua_gettop(L));
}
switch (what & LUA_ADDRESS_MASK) {
@@ -3946,7 +3948,7 @@ lua_task_get_from(lua_State *L)
if (task) {
if (lua_gettop(L) == 2) {
/* Get what value */
- what = lua_task_str_to_get_type(L, task, 2);
+ what = lua_task_str_to_get_type(L, task, 2, lua_gettop(L));
}
switch (what & LUA_ADDRESS_MASK) {
@@ -4017,7 +4019,7 @@ lua_task_set_from(lua_State *L)
gint what = 0;
if (task && lua_gettop(L) >= 3) {
- what = lua_task_str_to_get_type(L, task, 2);
+ what = lua_task_str_to_get_type(L, task, 2, -1);
if (lua_isstring(L, 4)) {
how = lua_tostring(L, 4);