aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/client/rspamc.c120
1 files changed, 119 insertions, 1 deletions
diff --git a/src/client/rspamc.c b/src/client/rspamc.c
index 9279682e4..3ed9f1dd4 100644
--- a/src/client/rspamc.c
+++ b/src/client/rspamc.c
@@ -46,6 +46,7 @@ static gint timeout = 5;
static gboolean pass_all;
static gboolean tty = FALSE;
static gboolean verbose = FALSE;
+static gboolean print_commands = FALSE;
static struct rspamd_client *client = NULL;
static GOptionEntry entries[] =
@@ -64,6 +65,7 @@ static GOptionEntry entries[] =
{ "rcpt", 'r', 0, G_OPTION_ARG_STRING, &rcpt, "Emulate that message is for specified user", NULL },
{ "timeout", 't', 0, G_OPTION_ARG_INT, &timeout, "Timeout for waiting for a reply", NULL },
{ "bind", 'b', 0, G_OPTION_ARG_STRING, &local_addr, "Bind to specified ip address", NULL },
+ { "commands", 0, 0, G_OPTION_ARG_NONE, &print_commands, "List available commands", NULL },
{ NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL }
};
@@ -82,6 +84,92 @@ enum rspamc_command {
RSPAMC_COMMAND_ADD_ACTION
};
+struct {
+ enum rspamc_command cmd;
+ const char *name;
+ const char *description;
+ gboolean is_controller;
+ gboolean is_privileged;
+} rspamc_command_help[] = {
+ {
+ .cmd = RSPAMC_COMMAND_SYMBOLS,
+ .name = "symbols",
+ .description = "scan message and show symbols (default command)",
+ .is_controller = FALSE,
+ .is_privileged = FALSE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_LEARN_SPAM,
+ .name = "learn_spam",
+ .description = "learn message as spam",
+ .is_controller = TRUE,
+ .is_privileged = TRUE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_LEARN_HAM,
+ .name = "learn_ham",
+ .description = "learn message as ham",
+ .is_controller = TRUE,
+ .is_privileged = TRUE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_FUZZY_ADD,
+ .name = "fuzzy_add",
+ .description = "add message to fuzzy storage (check -f and -w options for this command)",
+ .is_controller = TRUE,
+ .is_privileged = TRUE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_FUZZY_DEL,
+ .name = "fuzzy_del",
+ .description = "delete message from fuzzy storage (check -f option for this command)",
+ .is_controller = TRUE,
+ .is_privileged = TRUE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_STAT,
+ .name = "stat",
+ .description = "show rspamd statistics",
+ .is_controller = TRUE,
+ .is_privileged = FALSE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_STAT_RESET,
+ .name = "stat_reset",
+ .description = "show and reset rspamd statistics (useful for graphs)",
+ .is_controller = TRUE,
+ .is_privileged = TRUE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_COUNTERS,
+ .name = "counters",
+ .description = "display rspamd symbols statistics",
+ .is_controller = TRUE,
+ .is_privileged = FALSE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_UPTIME,
+ .name = "uptime",
+ .description = "show rspamd uptime",
+ .is_controller = TRUE,
+ .is_privileged = FALSE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_ADD_SYMBOL,
+ .name = "add_symbol",
+ .description = "add or modify symbol settings in rspamd",
+ .is_controller = TRUE,
+ .is_privileged = TRUE
+ },
+ {
+ .cmd = RSPAMC_COMMAND_ADD_ACTION,
+ .name = "add_action",
+ .description = "add or modify action settings",
+ .is_controller = TRUE,
+ .is_privileged = TRUE
+ }
+};
+
/*
* Parse command line
*/
@@ -151,6 +239,30 @@ check_rspamc_command (const gchar *cmd)
return RSPAMC_COMMAND_UNKNOWN;
}
+static void
+print_commands_list (void)
+{
+ guint i;
+
+ PRINT_FUNC ("Rspamc commands summary:\n");
+ for (i = 0; i < G_N_ELEMENTS (rspamc_command_help); i ++) {
+ if (tty) {
+ PRINT_FUNC (" \033[1m%10s\033[0m (%7s%1s)\t%s\n", rspamc_command_help[i].name,
+ rspamc_command_help[i].is_controller ? "control" : "normal",
+ rspamc_command_help[i].is_privileged ? "*" : "",
+ rspamc_command_help[i].description);
+ }
+ else {
+ PRINT_FUNC (" %10s (%7s%1s)\t%s\n", rspamc_command_help[i].name,
+ rspamc_command_help[i].is_controller ? "control" : "normal",
+ rspamc_command_help[i].is_privileged ? "*" : "",
+ rspamc_command_help[i].description);
+ }
+ }
+ PRINT_FUNC ("\n* is for privileged commands that may need password (see -P option)\n");
+ PRINT_FUNC ("control commands use port 11334 while normal use 11333 by default (see -h option)\n");
+}
+
/*
* Parse connect_str and add server to librspamdclient
*/
@@ -798,6 +910,13 @@ main (gint argc, gchar **argv, gchar **env)
read_cmd_line (&argc, &argv);
+ tty = isatty (STDOUT_FILENO);
+
+ if (print_commands) {
+ print_commands_list ();
+ exit (EXIT_SUCCESS);
+ }
+
if (local_addr) {
if (inet_aton (local_addr, &ina) != 0) {
client = rspamd_client_init_binded (&ina);
@@ -812,7 +931,6 @@ main (gint argc, gchar **argv, gchar **env)
}
rspamd_set_timeout (client, 1000, timeout * 1000);
- tty = isatty (STDOUT_FILENO);
/* Now read other args from argc and argv */
if (argc == 1) {
/* No args, just read stdin */