]> git.netwichtig.de Git - user/henk/code/inspircd.git/blob - src/commands/cmd_nick.cpp
5e600ad1ce676581c41c6f906772488b8ad90b88
[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 #include "xline.h"
25
26 /** Handle /NICK. These command handlers can be reloaded by the core,
27  * and handle basic RFC1459 commands. Commands within modules work
28  * the same way, however, they can be fully unloaded, where these
29  * may not.
30  */
31 class CommandNick : public Command
32 {
33  public:
34         /** Constructor for nick.
35          */
36         CommandNick ( Module* parent) : Command(parent,"NICK", 1, 1) { works_before_reg = true; syntax = "<newnick>"; Penalty = 0; }
37         /** Handle command.
38          * @param parameters The parameters to the comamnd
39          * @param pcnt The number of parameters passed to teh command
40          * @param user The user issuing the command
41          * @return A value from CmdResult to indicate command success or failure.
42          */
43         CmdResult Handle(const std::vector<std::string>& parameters, User *user);
44 };
45
46 /** Handle nick changes from users.
47  * NOTE: If you are used to ircds based on ircd2.8, and are looking
48  * for the client introduction code in here, youre in the wrong place.
49  * You need to look in the spanningtree module for this!
50  */
51 CmdResult CommandNick::Handle (const std::vector<std::string>& parameters, User *user)
52 {
53         std::string oldnick = user->nick;
54         std::string newnick = parameters[0];
55
56         // anything except the initial NICK gets a flood penalty
57         if (user->registered == REG_ALL && IS_LOCAL(user))
58                 IS_LOCAL(user)->CommandFloodPenalty += 4000;
59
60         if (newnick.empty())
61         {
62                 user->WriteNumeric(432, "%s * :Erroneous Nickname", oldnick.c_str());
63                 return CMD_FAILURE;
64         }
65
66         if (newnick == "0")
67         {
68                 newnick = user->uuid;
69         }
70         else if (!ServerInstance->IsNick(newnick.c_str(), ServerInstance->Config->Limits.NickMax))
71         {
72                 user->WriteNumeric(432, "%s %s :Erroneous Nickname", user->nick.c_str(),newnick.c_str());
73                 return CMD_FAILURE;
74         }
75
76         if (!user->ChangeNick(newnick, false))
77                 return CMD_FAILURE;
78
79         if (user->registered < REG_NICKUSER)
80         {
81                 user->registered = (user->registered | REG_NICK);
82                 if (user->registered == REG_NICKUSER)
83                 {
84                         /* user is registered now, bit 0 = USER command, bit 1 = sent a NICK command */
85                         ModResult MOD_RESULT;
86                         FIRST_MOD_RESULT(OnUserRegister, MOD_RESULT, (IS_LOCAL(user)));
87                         if (MOD_RESULT == MOD_RES_DENY)
88                                 return CMD_FAILURE;
89
90                         // return early to not penalize new users
91                         return CMD_SUCCESS;
92                 }
93         }
94
95         return CMD_SUCCESS;
96 }
97
98
99 COMMAND_INIT(CommandNick)