summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--docs/help/in/ban.in9
-rw-r--r--src/irc/core/bans.c87
2 files changed, 64 insertions, 32 deletions
diff --git a/docs/help/in/ban.in b/docs/help/in/ban.in
index 4f8a541d..53ca80ef 100644
--- a/docs/help/in/ban.in
+++ b/docs/help/in/ban.in
@@ -7,15 +7,16 @@ If nick is given as parameter, the ban type is used to generate the ban
mask. /SET ban_type specified the default ban type. Ban type is one of
the following:
- Normal - *!user@*.domain.net
+ Normal - *!*user@*.domain.net
+ User - *!*user@*
Host - *!*@host.domain.net
Domain - *!*@*.domain.net
Custom [nick] [user] [host] [domain]
Examples:
- /BAN looser - This bans the nick 'looser'
- /BAN *!*@*.org - This bans all the users coming from any
- .org domain.
+ /BAN looser - Bans the nick 'looser'
+ /BAN -host looser - Bans the host of nick 'looser'
+ /BAN *!*@*.org - Bans all the users coming from any .org domain.
/SET ban_type custom nick domain - nick!*@*.domain.net
/SET ban_type custom user host - *!user@host.domain.net
diff --git a/src/irc/core/bans.c b/src/irc/core/bans.c
index 0140cc75..8f4c535d 100644
--- a/src/irc/core/bans.c
+++ b/src/irc/core/bans.c
@@ -30,6 +30,11 @@
#include "irc.h"
#include "nicklist.h"
+#define BAN_TYPE_NORMAL (IRC_MASK_USER | IRC_MASK_DOMAIN)
+#define BAN_TYPE_USER (IRC_MASK_USER)
+#define BAN_TYPE_HOST (IRC_MASK_HOST | IRC_MASK_DOMAIN)
+#define BAN_TYPE_DOMAIN (IRC_MASK_DOMAIN)
+
static char *default_ban_type_str;
static int default_ban_type;
@@ -183,43 +188,57 @@ static void command_set_ban(const char *data, IRC_SERVER_REC *server,
cmd_params_free(free_arg);
}
-static int ban_parse_type(const char *type)
+static int parse_custom_ban(const char *type)
{
char **list;
int n, ban_type;
+ ban_type = 0;
+ list = g_strsplit(type, " ", -1);
+ for (n = 0; list[n] != NULL; n++) {
+ if (toupper(list[n][0]) == 'N')
+ ban_type |= IRC_MASK_NICK;
+ else if (toupper(list[n][0]) == 'U')
+ ban_type |= IRC_MASK_USER;
+ else if (toupper(list[n][0]) == 'H')
+ ban_type |= IRC_MASK_HOST | IRC_MASK_DOMAIN;
+ else if (toupper(list[n][0]) == 'D')
+ ban_type |= IRC_MASK_DOMAIN;
+ }
+ g_strfreev(list);
+
+ return ban_type;
+}
+
+static int parse_ban_type(const char *type)
+{
+ const char *pos;
+
g_return_val_if_fail(type != NULL, 0);
- ban_type = 0;
if (toupper(type[0]) == 'N')
- ban_type = IRC_MASK_USER | IRC_MASK_DOMAIN;
- else if (toupper(type[0]) == 'H')
- ban_type = IRC_MASK_HOST | IRC_MASK_DOMAIN;
- else if (toupper(type[0]) == 'D')
- ban_type = IRC_MASK_DOMAIN;
- else if (toupper(type[0]) == 'C') {
- list = g_strsplit(type, " ", -1);
- for (n = 1; list[n] != NULL; n++) {
- if (toupper(list[n][0]) == 'N')
- ban_type |= IRC_MASK_NICK;
- else if (toupper(list[n][0]) == 'U')
- ban_type |= IRC_MASK_USER;
- else if (toupper(list[n][0]) == 'H')
- ban_type |= IRC_MASK_HOST | IRC_MASK_DOMAIN;
- else if (toupper(list[n][0]) == 'D')
- ban_type |= IRC_MASK_DOMAIN;
- }
- g_strfreev(list);
+ return BAN_TYPE_NORMAL;
+ if (toupper(type[0]) == 'U')
+ return BAN_TYPE_USER;
+ if (toupper(type[0]) == 'H')
+ return BAN_TYPE_HOST;
+ if (toupper(type[0]) == 'D')
+ return BAN_TYPE_DOMAIN;
+ if (toupper(type[0]) == 'C') {
+ pos = strchr(type, ' ');
+ if (pos != NULL)
+ return parse_custom_ban(pos+1);
}
- return ban_type;
+ return 0;
}
-/* SYNTAX: BAN [-type <ban type>] <nicks/masks> */
+/* SYNTAX: BAN [-normal | -user | -host | -domain | -custom <type>] <nicks/masks> */
static void cmd_ban(const char *data, IRC_SERVER_REC *server, void *item)
{
GHashTable *optlist;
- char *ban, *ban_type_str;
+ const char *custom_type;
+ char *ban;
int ban_type;
void *free_arg;
@@ -228,9 +247,21 @@ static void cmd_ban(const char *data, IRC_SERVER_REC *server, void *item)
"ban", &optlist, &ban))
return;
- ban_type_str = g_hash_table_lookup(optlist, "type");
- ban_type = ban_type_str == NULL ? default_ban_type :
- ban_parse_type(ban_type_str);
+ if (g_hash_table_lookup(optlist, "normal") != NULL)
+ ban_type = BAN_TYPE_NORMAL;
+ else if (g_hash_table_lookup(optlist, "user") != NULL)
+ ban_type = BAN_TYPE_USER;
+ else if (g_hash_table_lookup(optlist, "host") != NULL)
+ ban_type = BAN_TYPE_HOST;
+ else if (g_hash_table_lookup(optlist, "domain") != NULL)
+ ban_type = BAN_TYPE_DOMAIN;
+ else {
+ custom_type = g_hash_table_lookup(optlist, "custom");
+ if (custom_type != NULL)
+ ban_type = parse_custom_ban(custom_type);
+ else
+ ban_type = default_ban_type;
+ }
command_set_ban(ban, server, item, TRUE, ban_type);
@@ -250,7 +281,7 @@ static void read_settings(void)
return;
g_free_not_null(default_ban_type_str);
- default_ban_type = ban_parse_type(settings_get_str("ban_type"));
+ default_ban_type = parse_ban_type(settings_get_str("ban_type"));
if (default_ban_type <= 0 || default_ban_type_str != NULL) {
signal_emit("ban type changed", 1,
GINT_TO_POINTER(default_ban_type));
@@ -269,7 +300,7 @@ void bans_init(void)
command_bind("ban", NULL, (SIGNAL_FUNC) cmd_ban);
command_bind("unban", NULL, (SIGNAL_FUNC) cmd_unban);
- command_set_options("ban", "+type");
+ command_set_options("ban", "normal user host domain +custom");
read_settings();
signal_add("setup changed", (SIGNAL_FUNC) read_settings);