summaryrefslogtreecommitdiffstats
path: root/src/client/rspamc.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/rspamc.c')
-rw-r--r--src/client/rspamc.c259
1 files changed, 247 insertions, 12 deletions
diff --git a/src/client/rspamc.c b/src/client/rspamc.c
index 1bae2970c..874c72074 100644
--- a/src/client/rspamc.c
+++ b/src/client/rspamc.c
@@ -34,7 +34,8 @@ static gchar *connect_str = "localhost";
static gchar *password;
static gchar *statfile;
static gchar *ip;
-static gdouble weight;
+static gint weight = 1;
+static gint flag;
static gboolean pass_all;
static gboolean tty = FALSE;
@@ -43,7 +44,8 @@ static GOptionEntry entries[] =
{ "connect", 'h', 0, G_OPTION_ARG_STRING, &connect_str, "Specify host and port", NULL },
{ "password", 'P', 0, G_OPTION_ARG_STRING, &password, "Specify control password", NULL },
{ "statfile", 's', 0, G_OPTION_ARG_STRING, &statfile, "Statfile to learn (symbol name)", NULL },
- { "weight", 'w', 0, G_OPTION_ARG_DOUBLE, &weight, "Weight for fuzzy operations", NULL },
+ { "weight", 'w', 0, G_OPTION_ARG_INT, &weight, "Weight for fuzzy operations", NULL },
+ { "flag", 'f', 0, G_OPTION_ARG_INT, &flag, "Flag for fuzzy operations", NULL },
{ "pass", 'p', 0, G_OPTION_ARG_NONE, &pass_all, "Pass all filters", NULL },
{ "ip", 'i', 0, G_OPTION_ARG_STRING, &ip, "Emulate that message was received from specified ip address", NULL },
{ NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL }
@@ -52,7 +54,10 @@ static GOptionEntry entries[] =
enum rspamc_command {
RSPAMC_COMMAND_UNKNOWN = 0,
RSPAMC_COMMAND_SYMBOLS,
- RSPAMC_COMMAND_LEARN
+ RSPAMC_COMMAND_LEARN,
+ RSPAMC_COMMAND_FUZZY_ADD,
+ RSPAMC_COMMAND_FUZZY_DEL,
+ RSPAMC_COMMAND_STAT
};
/*
@@ -93,6 +98,15 @@ check_rspamc_command (const gchar *cmd)
else if (g_ascii_strcasecmp (cmd, "LEARN") == 0) {
return RSPAMC_COMMAND_LEARN;
}
+ else if (g_ascii_strcasecmp (cmd, "FUZZY_ADD") == 0) {
+ return RSPAMC_COMMAND_FUZZY_ADD;
+ }
+ else if (g_ascii_strcasecmp (cmd, "FUZZY_DEL") == 0) {
+ return RSPAMC_COMMAND_FUZZY_DEL;
+ }
+ else if (g_ascii_strcasecmp (cmd, "STAT") == 0) {
+ return RSPAMC_COMMAND_STAT;
+ }
return RSPAMC_COMMAND_UNKNOWN;
}
@@ -282,6 +296,7 @@ scan_rspamd_stdin ()
exit (EXIT_FAILURE);
}
print_rspamd_result (res);
+ rspamd_free_result (res);
}
static void
@@ -302,9 +317,197 @@ scan_rspamd_file (const gchar *file)
g_hash_table_destroy (opts);
if (err != NULL) {
fprintf (stderr, "cannot scan message: %s\n", err->message);
- exit (EXIT_FAILURE);
}
print_rspamd_result (res);
+ if (res) {
+ rspamd_free_result (res);
+ }
+}
+
+static void
+learn_rspamd_stdin ()
+{
+ gchar *in_buf;
+ gint r = 0, len;
+ GError *err = NULL;
+
+ if (password == NULL || statfile == NULL) {
+ fprintf (stderr, "cannot learn message without password and symbol name\n");
+ exit (EXIT_FAILURE);
+ }
+ /* Add server */
+ add_rspamd_server (TRUE);
+
+ /* Allocate input buffer */
+ len = BUFSIZ;
+ in_buf = g_malloc (len);
+
+ /* Read stdin */
+ while (!feof (stdin)) {
+ r += fread (in_buf + r, 1, len - r, stdin);
+ if (len - r < len / 2) {
+ /* Grow buffer */
+ len *= 2;
+ in_buf = g_realloc (in_buf, len);
+ }
+ }
+ if (!rspamd_learn_memory (in_buf, r, statfile, password, &err)) {
+ if (err != NULL) {
+ fprintf (stderr, "cannot learn message: %s\n", err->message);
+ }
+ else {
+ fprintf (stderr, "cannot learn message\n");
+ }
+ exit (EXIT_FAILURE);
+ }
+ else {
+ if (tty) {
+ printf ("\033[1m");
+ }
+ PRINT_FUNC ("Results for host: %s: learn ok\n", connect_str);
+ if (tty) {
+ printf ("\033[0m");
+ }
+ }
+}
+
+static void
+learn_rspamd_file (const gchar *file)
+{
+ GError *err = NULL;
+
+ if (password == NULL || statfile == NULL) {
+ fprintf (stderr, "cannot learn message without password and symbol name\n");
+ exit (EXIT_FAILURE);
+ }
+ /* Add server */
+ add_rspamd_server (TRUE);
+
+ if (!rspamd_learn_file (file, statfile, password, &err)) {
+ if (err != NULL) {
+ fprintf (stderr, "cannot learn message: %s\n", err->message);
+ }
+ else {
+ fprintf (stderr, "cannot learn message\n");
+ }
+ }
+ else {
+ if (tty) {
+ printf ("\033[1m");
+ }
+ PRINT_FUNC ("learn ok\n");
+ if (tty) {
+ printf ("\033[0m");
+ }
+ }
+}
+
+static void
+fuzzy_rspamd_stdin (gboolean delete)
+{
+ gchar *in_buf;
+ gint r = 0, len;
+ GError *err = NULL;
+
+ if (password == NULL) {
+ fprintf (stderr, "cannot learn message without password\n");
+ exit (EXIT_FAILURE);
+ }
+ /* Add server */
+ add_rspamd_server (TRUE);
+
+ /* Allocate input buffer */
+ len = BUFSIZ;
+ in_buf = g_malloc (len);
+
+ /* Read stdin */
+ while (!feof (stdin)) {
+ r += fread (in_buf + r, 1, len - r, stdin);
+ if (len - r < len / 2) {
+ /* Grow buffer */
+ len *= 2;
+ in_buf = g_realloc (in_buf, len);
+ }
+ }
+ if (!rspamd_fuzzy_memory (in_buf, r, password, weight, flag, delete, &err)) {
+ if (err != NULL) {
+ fprintf (stderr, "cannot learn message: %s\n", err->message);
+ }
+ else {
+ fprintf (stderr, "cannot learn message\n");
+ }
+ exit (EXIT_FAILURE);
+ }
+ else {
+ if (tty) {
+ printf ("\033[1m");
+ }
+ PRINT_FUNC ("Results for host: %s: learn ok\n", connect_str);
+ if (tty) {
+ printf ("\033[0m");
+ }
+ }
+}
+
+static void
+fuzzy_rspamd_file (const gchar *file, gboolean delete)
+{
+ GError *err = NULL;
+
+ if (password == NULL) {
+ fprintf (stderr, "cannot learn message without password\n");
+ exit (EXIT_FAILURE);
+ }
+ /* Add server */
+ add_rspamd_server (TRUE);
+
+ if (!rspamd_fuzzy_file (file, password, weight, flag, delete, &err)) {
+ if (err != NULL) {
+ fprintf (stderr, "cannot learn message: %s\n", err->message);
+ }
+ else {
+ fprintf (stderr, "cannot learn message\n");
+ }
+ }
+ else {
+ if (tty) {
+ printf ("\033[1m");
+ }
+ PRINT_FUNC ("learn ok\n");
+ if (tty) {
+ printf ("\033[0m");
+ }
+ }
+}
+
+static void
+rspamd_do_stat ()
+{
+ GError *err = NULL;
+ GString *res;
+
+ /* Add server */
+ add_rspamd_server (TRUE);
+
+ res = rspamd_get_stat (&err);
+ if (res == NULL) {
+ if (err != NULL) {
+ fprintf (stderr, "cannot learn message: %s\n", err->message);
+ }
+ else {
+ fprintf (stderr, "cannot learn message\n");
+ }
+ exit (EXIT_FAILURE);
+ }
+ if (tty) {
+ printf ("\033[1m");
+ }
+ PRINT_FUNC ("Results for host: %s\n\n", connect_str);
+ if (tty) {
+ printf ("\033[0m");
+ }
+ res = g_string_append_c (res, '\0');
+ printf ("%s\n", res->str);
}
gint
@@ -326,11 +529,24 @@ main (gint argc, gchar **argv, gchar **env)
/* One argument is whether command or filename */
if ((cmd = check_rspamc_command (argv[1])) != RSPAMC_COMMAND_UNKNOWN) {
/* In case of command read stdin */
- if (cmd == RSPAMC_COMMAND_SYMBOLS) {
+ switch (cmd) {
+ case RSPAMC_COMMAND_SYMBOLS:
scan_rspamd_stdin ();
- }
- else {
- /* XXX: implement this */
+ break;
+ case RSPAMC_COMMAND_LEARN:
+ learn_rspamd_stdin ();
+ break;
+ case RSPAMC_COMMAND_FUZZY_ADD:
+ fuzzy_rspamd_stdin (FALSE);
+ break;
+ case RSPAMC_COMMAND_FUZZY_DEL:
+ fuzzy_rspamd_stdin (TRUE);
+ break;
+ case RSPAMC_COMMAND_STAT:
+ rspamd_do_stat ();
+ default:
+ fprintf (stderr, "invalid arguments\n");
+ exit (EXIT_FAILURE);
}
}
else {
@@ -341,11 +557,29 @@ main (gint argc, gchar **argv, gchar **env)
if ((cmd = check_rspamc_command (argv[1])) != RSPAMC_COMMAND_UNKNOWN) {
/* In case of command read arguments starting from 2 */
for (i = 2; i < argc; i ++) {
- if (cmd == RSPAMC_COMMAND_SYMBOLS) {
- scan_rspamd_file (argv[i]);
+ if (tty) {
+ printf ("\033[1m");
}
- else {
- /* XXX: implement this */
+ PRINT_FUNC ("Results for file: %s\n\n", argv[i]);
+ if (tty) {
+ printf ("\033[0m");
+ }
+ switch (cmd) {
+ case RSPAMC_COMMAND_SYMBOLS:
+ scan_rspamd_file (argv[i]);
+ break;
+ case RSPAMC_COMMAND_LEARN:
+ learn_rspamd_file (argv[i]);
+ break;
+ case RSPAMC_COMMAND_FUZZY_ADD:
+ fuzzy_rspamd_file (argv[i], FALSE);
+ break;
+ case RSPAMC_COMMAND_FUZZY_DEL:
+ fuzzy_rspamd_file (argv[i], TRUE);
+ break;
+ default:
+ fprintf (stderr, "invalid arguments\n");
+ exit (EXIT_FAILURE);
}
}
}
@@ -356,6 +590,7 @@ main (gint argc, gchar **argv, gchar **env)
}
}
+ rspamd_client_close ();
return 0;
}