mirror of
https://github.com/jeremyd/ergo.git
synced 2026-05-17 21:34:47 -07:00
nickname: Preserve case when setting NICK
This commit is contained in:
@@ -17,15 +17,16 @@ func nickHandler(server *Server, client *Client, msg ircmsg.IrcMessage) bool {
|
|||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
nickname, err := CasefoldName(msg.Params[0])
|
nicknameRaw := strings.TrimSpace(msg.Params[0])
|
||||||
|
nickname, err := CasefoldName(nicknameRaw)
|
||||||
|
|
||||||
if len(strings.TrimSpace(msg.Params[0])) < 1 {
|
if len(nicknameRaw) < 1 {
|
||||||
client.Send(nil, server.name, ERR_NONICKNAMEGIVEN, client.nick, "No nickname given")
|
client.Send(nil, server.name, ERR_NONICKNAMEGIVEN, client.nick, "No nickname given")
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
if err != nil || len(strings.TrimSpace(msg.Params[0])) > server.limits.NickLen {
|
if err != nil || len(nicknameRaw) > server.limits.NickLen {
|
||||||
client.Send(nil, server.name, ERR_ERRONEUSNICKNAME, client.nick, msg.Params[0], "Erroneous nickname")
|
client.Send(nil, server.name, ERR_ERRONEUSNICKNAME, client.nick, nicknameRaw, "Erroneous nickname")
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -36,14 +37,14 @@ func nickHandler(server *Server, client *Client, msg ircmsg.IrcMessage) bool {
|
|||||||
//TODO(dan): There's probably some races here, we should be changing this in the primary server thread
|
//TODO(dan): There's probably some races here, we should be changing this in the primary server thread
|
||||||
target := server.clients.Get(nickname)
|
target := server.clients.Get(nickname)
|
||||||
if target != nil && target != client {
|
if target != nil && target != client {
|
||||||
client.Send(nil, server.name, ERR_NICKNAMEINUSE, client.nick, msg.Params[0], "Nickname is already in use")
|
client.Send(nil, server.name, ERR_NICKNAMEINUSE, client.nick, nicknameRaw, "Nickname is already in use")
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
if client.registered {
|
if client.registered {
|
||||||
client.ChangeNickname(nickname)
|
client.ChangeNickname(nicknameRaw)
|
||||||
} else {
|
} else {
|
||||||
client.SetNickname(nickname)
|
client.SetNickname(nicknameRaw)
|
||||||
}
|
}
|
||||||
server.tryRegister(client)
|
server.tryRegister(client)
|
||||||
return false
|
return false
|
||||||
|
|||||||
Reference in New Issue
Block a user