From e639f5b360321d5c95abecf81861137d7f02594a Mon Sep 17 00:00:00 2001 From: Doug Freed Date: Thu, 13 Jun 2024 06:42:33 -0500 Subject: [PATCH] s_user: reject invalid usernames before anything else This way invalid characters in usernames only appear in this snote, and all other rejection snotes will always have clean usernames. --- ircd/s_user.c | 52 +++++++++++++++++++++++++-------------------------- 1 file changed, 26 insertions(+), 26 deletions(-) diff --git a/ircd/s_user.c b/ircd/s_user.c index 46f11b51..cbfeab7b 100644 --- a/ircd/s_user.c +++ b/ircd/s_user.c @@ -409,6 +409,32 @@ register_local_user(struct Client *client_p, struct Client *source_p) else rb_strlcpy(notildeusername, source_p->username, sizeof notildeusername); + /* valid user name check */ + + if(!valid_username(source_p->username)) + { + sendto_realops_snomask(SNO_REJ, L_NETWIDE, + "Invalid username: %s (%s@%s)", + source_p->name, source_p->username, source_p->host); + + const char *illegal_name_long_client_message = ConfigFileEntry.illegal_name_long_client_message; + const char *illegal_name_short_client_message = ConfigFileEntry.illegal_name_short_client_message; + + if (illegal_name_long_client_message == NULL) + illegal_name_long_client_message = "Your username is invalid. Please make sure that your username contains " + "only alphanumeric characters."; + if (illegal_name_short_client_message == NULL) + illegal_name_short_client_message = "Invalid username"; + + ServerStats.is_ref++; + sendto_one_notice(source_p, ":*** %s", illegal_name_long_client_message); + sprintf(tmpstr2, "%s [%s]", illegal_name_short_client_message, source_p->username); + exit_client(client_p, source_p, &me, tmpstr2); + return (CLIENT_EXITED); + } + + /* end of valid user name check */ + if((status = check_client(client_p, source_p, notildeusername)) < 0) return (CLIENT_EXITED); @@ -593,32 +619,6 @@ register_local_user(struct Client *client_p, struct Client *source_p) if(authd_check(client_p, source_p)) return CLIENT_EXITED; - /* valid user name check */ - - if(!valid_username(source_p->username)) - { - sendto_realops_snomask(SNO_REJ, L_NETWIDE, - "Invalid username: %s (%s@%s)", - source_p->name, source_p->username, source_p->host); - - const char *illegal_name_long_client_message = ConfigFileEntry.illegal_name_long_client_message; - const char *illegal_name_short_client_message = ConfigFileEntry.illegal_name_short_client_message; - - if (illegal_name_long_client_message == NULL) - illegal_name_long_client_message = "Your username is invalid. Please make sure that your username contains " - "only alphanumeric characters."; - if (illegal_name_short_client_message == NULL) - illegal_name_short_client_message = "Invalid username"; - - ServerStats.is_ref++; - sendto_one_notice(source_p, ":*** %s", illegal_name_long_client_message); - sprintf(tmpstr2, "%s [%s]", illegal_name_short_client_message, source_p->username); - exit_client(client_p, source_p, &me, tmpstr2); - return (CLIENT_EXITED); - } - - /* end of valid user name check */ - /* Store original hostname -- jilles */ rb_strlcpy(source_p->orighost, source_p->host, HOSTLEN + 1);