mirror of
https://github.com/weechat/weechat.git
synced 2026-07-02 15:53:12 +02:00
irc: check that the first nick char is not a prefix char or chantype in function irc_nick_is_nick
This commit is contained in:
@@ -72,13 +72,17 @@ irc_nick_valid (struct t_irc_channel *channel, struct t_irc_nick *nick)
|
||||
int
|
||||
irc_nick_is_nick (struct t_irc_server *server, const char *string)
|
||||
{
|
||||
const char *ptr_string;
|
||||
const char *ptr_string, *ptr_prefix_chars, *ptr_chantypes;
|
||||
int utf8mapping;
|
||||
|
||||
if (!string || !string[0])
|
||||
return 0;
|
||||
|
||||
utf8mapping = (server) ? server->utf8mapping : IRC_SERVER_UTF8MAPPING_NONE;
|
||||
ptr_prefix_chars = (server && server->prefix_chars) ?
|
||||
server->prefix_chars : irc_server_prefix_chars_default;
|
||||
ptr_chantypes = (server && server->chantypes) ?
|
||||
server->chantypes : irc_channel_default_chantypes;
|
||||
|
||||
/* check length of nick in bytes (if we have a limit in the server) */
|
||||
if (server && (server->nick_max_length > 0)
|
||||
@@ -103,18 +107,23 @@ irc_nick_is_nick (struct t_irc_server *server, const char *string)
|
||||
/* first char is invalid */
|
||||
return 0;
|
||||
}
|
||||
if (strchr (ptr_prefix_chars, string[0])
|
||||
|| strchr (ptr_chantypes, string[0]))
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* check if there are forbidden chars in nick */
|
||||
ptr_string = string;
|
||||
while (ptr_string && ptr_string[0])
|
||||
{
|
||||
if ((utf8mapping == IRC_SERVER_UTF8MAPPING_NONE)
|
||||
&& !strchr (IRC_NICK_VALID_CHARS, ptr_string[0]))
|
||||
&& !strchr (IRC_NICK_VALID_CHARS_RFC1459, ptr_string[0]))
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
if ((utf8mapping == IRC_SERVER_UTF8MAPPING_RFC8265)
|
||||
&& strchr (IRC_NICK_INVALID_CHARS, ptr_string[0]))
|
||||
&& strchr (IRC_NICK_INVALID_CHARS_RFC8265, ptr_string[0]))
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -20,9 +20,9 @@
|
||||
#ifndef WEECHAT_PLUGIN_IRC_NICK_H
|
||||
#define WEECHAT_PLUGIN_IRC_NICK_H
|
||||
|
||||
#define IRC_NICK_VALID_CHARS "abcdefghijklmnopqrstuvwxyzABCDEFGHI" \
|
||||
#define IRC_NICK_VALID_CHARS_RFC1459 "abcdefghijklmnopqrstuvwxyzABCDEFGHI" \
|
||||
"JKLMNOPQRSTUVWXYZ0123456789-[]\\`_^{|}"
|
||||
#define IRC_NICK_INVALID_CHARS " ,:\n\r*?.!@"
|
||||
#define IRC_NICK_INVALID_CHARS_RFC8265 " ,:\n\r*?.!@"
|
||||
|
||||
/* nicklist group for nicks without prefix is "999|..." */
|
||||
#define IRC_NICK_GROUP_OTHER_NUMBER 999
|
||||
|
||||
@@ -282,6 +282,9 @@ enum t_irc_fingerprint_digest_algo
|
||||
IRC_FINGERPRINT_NUM_ALGOS,
|
||||
};
|
||||
|
||||
extern char *irc_server_prefix_modes_default;
|
||||
extern char *irc_server_prefix_chars_default;
|
||||
extern char *irc_server_chanmodes_default;
|
||||
extern struct t_irc_server *irc_servers;
|
||||
extern const int gnutls_cert_type_prio[];
|
||||
extern const int gnutls_prot_prio[];
|
||||
|
||||
@@ -23,6 +23,7 @@
|
||||
|
||||
extern "C"
|
||||
{
|
||||
#include <string.h>
|
||||
#include "src/plugins/irc/irc-nick.h"
|
||||
#include "src/plugins/irc/irc-server.h"
|
||||
}
|
||||
@@ -57,11 +58,19 @@ TEST(IrcNick, IsNick)
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, ""));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, " "));
|
||||
|
||||
/* invalid first char */
|
||||
/* invalid first char (rfc1459) */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "0abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "9abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "-abc"));
|
||||
|
||||
/* invalid first char: prefix char */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "@abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "+abc"));
|
||||
|
||||
/* invalid first char: chantypes */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "#abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "&abc"));
|
||||
|
||||
/* invalid chars in nick */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "nick test"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (NULL, "nick,test"));
|
||||
@@ -80,13 +89,23 @@ TEST(IrcNick, IsNick)
|
||||
LONGS_EQUAL(1, irc_nick_is_nick (NULL, "alice"));
|
||||
LONGS_EQUAL(1, irc_nick_is_nick (NULL, "very_long_nick_which_is_valid"));
|
||||
|
||||
/* server with utf8mapping = rfc8265, nicklen = 20 */
|
||||
/*
|
||||
* server with:
|
||||
* utf8mapping = rfc8265
|
||||
* nicklen = 20
|
||||
* prefix = (qaohv)~&@%+
|
||||
* chantypes = #
|
||||
*/
|
||||
server = irc_server_alloc ("my_ircd");
|
||||
CHECK(server);
|
||||
if (server->chantypes)
|
||||
free (server->chantypes);
|
||||
server->utf8mapping =IRC_SERVER_UTF8MAPPING_RFC8265;
|
||||
server->utf8mapping = IRC_SERVER_UTF8MAPPING_RFC8265;
|
||||
server->nick_max_length = 20;
|
||||
irc_server_set_prefix_modes_chars (server, "(qaohv)~&@%+");
|
||||
if (server->chantypes)
|
||||
free (server->chantypes);
|
||||
server->chantypes = strdup ("#");
|
||||
|
||||
/* empty nick */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, NULL));
|
||||
@@ -101,6 +120,16 @@ TEST(IrcNick, IsNick)
|
||||
LONGS_EQUAL(1, irc_nick_is_nick (server, "9abc"));
|
||||
LONGS_EQUAL(1, irc_nick_is_nick (server, "-abc"));
|
||||
|
||||
/* invalid first char: prefix char */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "~abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "&abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "@abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "%abc"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "+abc"));
|
||||
|
||||
/* invalid first char: chantypes */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "#abc"));
|
||||
|
||||
/* invalid chars in nick */
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "nick test"));
|
||||
LONGS_EQUAL(0, irc_nick_is_nick (server, "nick,test"));
|
||||
|
||||
Reference in New Issue
Block a user