diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-03-20 17:04:45 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-03-20 17:04:45 +0000 |
commit | 4d56fed92bbbcee00056d448940f1edc422292c6 (patch) | |
tree | f50a180baf2269bb6391b9c39f92405b890c5c16 /src/libmime | |
parent | fc2be8c5765f01710c795832999c6dea72335d06 (diff) | |
download | rspamd-4d56fed92bbbcee00056d448940f1edc422292c6.tar.gz rspamd-4d56fed92bbbcee00056d448940f1edc422292c6.zip |
Add guards for function arguments.
Diffstat (limited to 'src/libmime')
-rw-r--r-- | src/libmime/mime_expressions.c | 32 |
1 files changed, 30 insertions, 2 deletions
diff --git a/src/libmime/mime_expressions.c b/src/libmime/mime_expressions.c index 8d5f08c2b..1072140b2 100644 --- a/src/libmime/mime_expressions.c +++ b/src/libmime/mime_expressions.c @@ -947,7 +947,7 @@ rspamd_compare_encoding (struct rspamd_task *task, GArray * args, void *unused) } arg = &g_array_index (args, struct expression_argument, 0); - if (!arg || arg->type == EXPRESSION_ARGUMENT_BOOL) { + if (!arg || arg->type != EXPRESSION_ARGUMENT_NORMAL) { msg_warn ("invalid argument to function is passed"); return FALSE; } @@ -967,7 +967,7 @@ rspamd_header_exists (struct rspamd_task * task, GArray * args, void *unused) } arg = &g_array_index (args, struct expression_argument, 0); - if (!arg || arg->type == EXPRESSION_ARGUMENT_BOOL) { + if (!arg || arg->type != EXPRESSION_ARGUMENT_NORMAL) { msg_warn ("invalid argument to function is passed"); return FALSE; } @@ -1006,6 +1006,11 @@ rspamd_parts_distance (struct rspamd_task * task, GArray * args, void *unused) else { errno = 0; arg = &g_array_index (args, struct expression_argument, 0); + if (!arg || arg->type != EXPRESSION_ARGUMENT_NORMAL) { + msg_warn ("invalid argument to function is passed"); + return FALSE; + } + threshold = strtoul ((gchar *)arg->data, NULL, 10); if (errno != 0) { msg_info ("bad numeric value for threshold \"%s\", assume it 100", @@ -1014,6 +1019,11 @@ rspamd_parts_distance (struct rspamd_task * task, GArray * args, void *unused) } if (args->len == 1) { arg = &g_array_index (args, struct expression_argument, 1); + if (!arg || arg->type != EXPRESSION_ARGUMENT_NORMAL) { + msg_warn ("invalid argument to function is passed"); + return FALSE; + } + errno = 0; threshold2 = strtoul ((gchar *)arg->data, NULL, 10); if (errno != 0) { @@ -1171,8 +1181,14 @@ rspamd_recipients_distance (struct rspamd_task *task, GArray * args, } arg = &g_array_index (args, struct expression_argument, 0); + if (!arg || arg->type != EXPRESSION_ARGUMENT_NORMAL) { + msg_warn ("invalid argument to function is passed"); + return FALSE; + } + errno = 0; threshold = strtod ((gchar *)arg->data, NULL); + if (errno != 0) { msg_warn ("invalid numeric value '%s': %s", (gchar *)arg->data, @@ -1183,7 +1199,9 @@ rspamd_recipients_distance (struct rspamd_task *task, GArray * args, if (!task->rcpt_mime) { return FALSE; } + num = internet_address_list_length (task->rcpt_mime); + if (num < MIN_RCPT_TO_COMPARE) { return FALSE; } @@ -1374,6 +1392,11 @@ rspamd_compare_transfer_encoding (struct rspamd_task * task, } arg = &g_array_index (args, struct expression_argument, 0); + if (!arg || arg->type != EXPRESSION_ARGUMENT_NORMAL) { + msg_warn ("invalid argument to function is passed"); + return FALSE; + } + #ifndef GMIME24 enc_req = g_mime_part_encoding_from_string (arg->data); if (enc_req == GMIME_PART_ENCODING_DEFAULT) { @@ -1484,6 +1507,11 @@ rspamd_has_html_tag (struct rspamd_task * task, GArray * args, void *unused) } arg = &g_array_index (args, struct expression_argument, 0); + if (!arg || arg->type != EXPRESSION_ARGUMENT_NORMAL) { + msg_warn ("invalid argument to function is passed"); + return FALSE; + } + tag = get_tag_by_name (arg->data); if (tag == NULL) { msg_warn ("unknown tag type passed as argument: %s", |