aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWilmer van der Gaast <wilmer@gaast.net>2010-05-23 15:31:30 +0100
committerWilmer van der Gaast <wilmer@gaast.net>2010-05-23 15:31:30 +0100
commit228fc188af4cc292a14672abe519d557d57bb1e6 (patch)
tree2f358f07c8697ecbf371c7336658e6f27d238b80
parent186bd04be06297c1dd480f730eef8fcede9a3991 (diff)
Allow nick changes. (Based on patch from zibri) This mostly closes #6!
-rw-r--r--irc_commands.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/irc_commands.c b/irc_commands.c
index 319d549a..7a286ce2 100644
--- a/irc_commands.c
+++ b/irc_commands.c
@@ -72,19 +72,29 @@ static void irc_cmd_user( irc_t *irc, char **cmd )
static void irc_cmd_nick( irc_t *irc, char **cmd )
{
- if( irc->nick )
+ if( irc->status & USTATUS_IDENTIFIED && irc->nick )
{
- irc_reply( irc, 438, ":The hand of the deity is upon thee, thy nick may not change" );
+ irc_reply( irc, 438, "%s %s :You can only change your nick if you're not "
+ "logged in (i.e. pre-identify)", irc->nick, cmd[1] );
}
/* This is not clean, but for now it'll have to be like this... */
- else if( ( nick_cmp( cmd[1], irc->mynick ) == 0 ) || ( nick_cmp( cmd[1], NS_NICK ) == 0 ) )
+ else if( ( nick_cmp( cmd[1], irc->mynick ) == 0 ) || ( nick_cmp( cmd[1], NS_NICK ) == 0 ) || ( user_find( irc, cmd[1] ) != NULL ) )
{
- irc_reply( irc, 433, ":This nick is already in use" );
+ irc_reply( irc, 433, "%s :This nick is already in use", cmd[1] );
}
else if( !nick_ok( cmd[1] ) )
{
/* [SH] Invalid characters. */
- irc_reply( irc, 432, ":This nick contains invalid characters" );
+ irc_reply( irc, 432, "%s :This nick contains invalid characters", cmd[1] );
+ }
+ else if(irc->nick)
+ {
+ if( user_find( irc, irc->nick ) )
+ user_rename(irc, irc->nick, cmd[1]);
+
+ irc_write( irc, ":%s!%s@%s NICK %s", irc->nick, irc->user, irc->host, cmd[1] );
+ g_free(irc->nick);
+ irc->nick = g_strdup( cmd[1] );
}
else
{