]> git.netwichtig.de Git - user/henk/code/inspircd.git/blob - src/commands/cmd_nick.cpp
Release v2.0.20
[user/henk/code/inspircd.git] / src / commands / cmd_nick.cpp
1 /*
2  * InspIRCd -- Internet Relay Chat Daemon
3  *
4  *   Copyright (C) 2009-2010 Daniel De Graaf <danieldg@inspircd.org>
5  *   Copyright (C) 2008 Craig Edwards <craigedwards@brainbox.cc>
6  *   Copyright (C) 2008 Thomas Stagner <aquanight@inspircd.org>
7  *   Copyright (C) 2007-2008 Robin Burchell <robin+git@viroteck.net>
8  *
9  * This file is part of InspIRCd.  InspIRCd is free software: you can
10  * redistribute it and/or modify it under the terms of the GNU General Public
11  * License as published by the Free Software Foundation, version 2.
12  *
13  * This program is distributed in the hope that it will be useful, but WITHOUT
14  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
20  */
21
22
23 #include "inspircd.h"
24
25 /** Handle /NICK. These command handlers can be reloaded by the core,
26  * and handle basic RFC1459 commands. Commands within modules work
27  * the same way, however, they can be fully unloaded, where these
28  * may not.
29  */
30 class CommandNick : public Command
31 {
32  public:
33         /** Constructor for nick.
34          */
35         CommandNick ( Module* parent) : Command(parent,"NICK", 1, 1) { works_before_reg = true; syntax = "<newnick>"; Penalty = 0; }
36         /** Handle command.
37          * @param parameters The parameters to the comamnd
38          * @param pcnt The number of parameters passed to teh command
39          * @param user The user issuing the command
40          * @return A value from CmdResult to indicate command success or failure.
41          */
42         CmdResult Handle(const std::vector<std::string>& parameters, User *user);
43 };
44
45 /** Handle nick changes from users.
46  * NOTE: If you are used to ircds based on ircd2.8, and are looking
47  * for the client introduction code in here, youre in the wrong place.
48  * You need to look in the spanningtree module for this!
49  */
50 CmdResult CommandNick::Handle (const std::vector<std::string>& parameters, User *user)
51 {
52         std::string oldnick = user->nick;
53         std::string newnick = parameters[0];
54
55         // anything except the initial NICK gets a flood penalty
56         if (user->registered == REG_ALL && IS_LOCAL(user))
57                 IS_LOCAL(user)->CommandFloodPenalty += 4000;
58
59         if (newnick.empty())
60         {
61                 user->WriteNumeric(432, "%s * :Erroneous Nickname", oldnick.c_str());
62                 return CMD_FAILURE;
63         }
64
65         if (newnick == "0")
66         {
67                 newnick = user->uuid;
68         }
69         else if (!ServerInstance->IsNick(newnick.c_str(), ServerInstance->Config->Limits.NickMax))
70         {
71                 user->WriteNumeric(432, "%s %s :Erroneous Nickname", user->nick.c_str(),newnick.c_str());
72                 return CMD_FAILURE;
73         }
74
75         if (!user->ChangeNick(newnick, false))
76                 return CMD_FAILURE;
77
78         if (user->registered < REG_NICKUSER)
79         {
80                 user->registered = (user->registered | REG_NICK);
81                 if (user->registered == REG_NICKUSER)
82                 {
83                         /* user is registered now, bit 0 = USER command, bit 1 = sent a NICK command */
84                         ModResult MOD_RESULT;
85                         FIRST_MOD_RESULT(OnUserRegister, MOD_RESULT, (IS_LOCAL(user)));
86                         if (MOD_RESULT == MOD_RES_DENY)
87                                 return CMD_FAILURE;
88
89                         // return early to not penalize new users
90                         return CMD_SUCCESS;
91                 }
92         }
93
94         return CMD_SUCCESS;
95 }
96
97
98 COMMAND_INIT(CommandNick)