aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2018-04-27 19:47:38 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2018-04-27 19:47:38 +0100
commit72188b4603199e31025360e75cb26a5d9cb90ad7 (patch)
tree9fbd90c7444972ed67b63e429e3b094b5a2b96ea /src
parent6d34197ef90dcc50a85c5e2029e03ec87a593edb (diff)
downloadrspamd-72188b4603199e31025360e75cb26a5d9cb90ad7.tar.gz
rspamd-72188b4603199e31025360e75cb26a5d9cb90ad7.zip
[Feature] Implement exclude patterns in rspamc
Issue: #2172 Closes: #2172
Diffstat (limited to 'src')
-rw-r--r--src/client/rspamc.c56
1 files changed, 52 insertions, 4 deletions
diff --git a/src/client/rspamc.c b/src/client/rspamc.c
index a8139d1ca..201e80403 100644
--- a/src/client/rspamc.c
+++ b/src/client/rspamc.c
@@ -41,6 +41,7 @@ static gchar *local_addr = NULL;
static gchar *execute = NULL;
static gchar *sort = NULL;
static gchar **http_headers = NULL;
+static gchar **exclude_patterns = NULL;
static gint weight = 0;
static gint flag = 0;
static gchar *fuzzy_symbol = NULL;
@@ -65,6 +66,7 @@ static gboolean skip_attachments = FALSE;
static gchar *key = NULL;
static gchar *user_agent = "rspamc";
static GList *children;
+static GPatternSpec **exclude_compiled = NULL;
#define ADD_CLIENT_HEADER(o, n, v) do { \
struct rspamd_http_client_header *nh; \
@@ -136,6 +138,8 @@ static GOptionEntry entries[] =
"Write mime body of message with headers instead of just a scan's result", NULL },
{"header", 0, 0, G_OPTION_ARG_STRING_ARRAY, &http_headers,
"Add custom HTTP header to query (can be repeated)", NULL},
+ {"exclude", 0, 0, G_OPTION_ARG_STRING_ARRAY, &exclude_patterns,
+ "Exclude specific glob patterns in file names (can be repeated)", NULL},
{"sort", 0, 0, G_OPTION_ARG_STRING, &sort,
"Sort output in a specific order (name, weight, time)", NULL},
{ "empty", 'E', 0, G_OPTION_ARG_NONE, &empty_input,
@@ -1698,12 +1702,13 @@ rspamc_process_dir (struct event_base *ev_base, struct rspamc_command *cmd,
const gchar *name, GQueue *attrs)
{
DIR *d;
+ GPatternSpec **ex;
struct dirent *pentry;
- gint cur_req = 0;
+ gint cur_req = 0, r;
gchar fpath[PATH_MAX];
FILE *in;
struct stat st;
- gboolean is_reg, is_dir;
+ gboolean is_reg, is_dir, skip;
d = opendir (name);
@@ -1714,10 +1719,26 @@ rspamc_process_dir (struct event_base *ev_base, struct rspamc_command *cmd,
continue;
}
- rspamd_snprintf (fpath, sizeof (fpath), "%s%c%s",
+ r = rspamd_snprintf (fpath, sizeof (fpath), "%s%c%s",
name, G_DIR_SEPARATOR,
pentry->d_name);
+ /* Check exclude */
+ ex = exclude_compiled;
+ skip = FALSE;
+ while (ex != NULL && *ex != NULL) {
+ if (g_pattern_match (*ex, r, fpath, NULL)) {
+ skip = TRUE;
+ break;
+ }
+
+ ex ++;
+ }
+
+ if (skip) {
+ continue;
+ }
+
is_reg = FALSE;
is_dir = FALSE;
@@ -1787,7 +1808,7 @@ rspamc_process_dir (struct event_base *ev_base, struct rspamc_command *cmd,
gint
main (gint argc, gchar **argv, gchar **env)
{
- gint i, start_argc, cur_req = 0, res, ret;
+ gint i, start_argc, cur_req = 0, res, ret, npatterns;
GQueue *kwattrs;
GList *cur;
GPid cld;
@@ -1796,6 +1817,7 @@ main (gint argc, gchar **argv, gchar **env)
struct event_base *ev_base;
struct stat st;
struct sigaction sigpipe_act;
+ gchar **exclude_pattern;
kwattrs = g_queue_new ();
@@ -1808,6 +1830,28 @@ main (gint argc, gchar **argv, gchar **env)
exit (EXIT_SUCCESS);
}
+ /* Deal with exclude patterns */
+ exclude_pattern = exclude_patterns;
+ npatterns = 0;
+
+ while (exclude_pattern && *exclude_pattern) {
+ npatterns ++;
+ }
+
+ if (npatterns > 0) {
+ exclude_compiled = g_malloc0 (sizeof (*exclude_compiled) * (npatterns + 1));
+
+ for (i = 0; i < npatterns; i ++) {
+ exclude_compiled[i] = g_pattern_spec_new (exclude_patterns[i]);
+
+ if (exclude_compiled[i] == NULL) {
+ rspamd_fprintf (stderr, "Invalid glob pattern: %s\n",
+ exclude_patterns[i]);
+ exit (EXIT_FAILURE);
+ }
+ }
+ }
+
rspamd_init_libs ();
ev_base = event_base_new ();
@@ -1949,5 +1993,9 @@ main (gint argc, gchar **argv, gchar **env)
g_list_free (children);
}
+ for (i = 0; i < npatterns; i ++) {
+ g_pattern_spec_free (exclude_compiled[i]);
+ }
+
return ret;
}