]> git.netwichtig.de Git - user/henk/code/inspircd.git/blob - src/commands/cmd_names.cpp
m_services_account Send an AccountEvent with an empty accountname when a user logs...
[user/henk/code/inspircd.git] / src / commands / cmd_names.cpp
1 /*
2  * InspIRCd -- Internet Relay Chat Daemon
3  *
4  *   Copyright (C) 2009 Daniel De Graaf <danieldg@inspircd.org>
5  *   Copyright (C) 2007 Robin Burchell <robin+git@viroteck.net>
6  *
7  * This file is part of InspIRCd.  InspIRCd is free software: you can
8  * redistribute it and/or modify it under the terms of the GNU General Public
9  * License as published by the Free Software Foundation, version 2.
10  *
11  * This program is distributed in the hope that it will be useful, but WITHOUT
12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
13  * FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
14  * details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20
21 #include "inspircd.h"
22
23 #ifndef CMD_NAMES_H
24 #define CMD_NAMES_H
25
26 // include the common header files
27
28 #include "users.h"
29 #include "channels.h"
30
31 /** Handle /NAMES. These command handlers can be reloaded by the core,
32  * and handle basic RFC1459 commands. Commands within modules work
33  * the same way, however, they can be fully unloaded, where these
34  * may not.
35  */
36 class CommandNames : public Command
37 {
38  public:
39         /** Constructor for names.
40          */
41         CommandNames ( Module* parent) : Command(parent,"NAMES",0,0) { syntax = "{<channel>{,<channel>}}"; }
42         /** Handle command.
43          * @param parameters The parameters to the comamnd
44          * @param pcnt The number of parameters passed to teh command
45          * @param user The user issuing the command
46          * @return A value from CmdResult to indicate command success or failure.
47          */
48         CmdResult Handle(const std::vector<std::string>& parameters, User *user);
49 };
50
51 #endif
52
53
54 /** Handle /NAMES
55  */
56 CmdResult CommandNames::Handle (const std::vector<std::string>& parameters, User *user)
57 {
58         Channel* c;
59
60         if (!parameters.size())
61         {
62                 user->WriteNumeric(366, "%s * :End of /NAMES list.",user->nick.c_str());
63                 return CMD_SUCCESS;
64         }
65
66         if (ServerInstance->Parser->LoopCall(user, this, parameters, 0))
67                 return CMD_SUCCESS;
68
69         c = ServerInstance->FindChan(parameters[0]);
70         if (c)
71         {
72                 if ((c->IsModeSet('s')) && (!c->HasUser(user)))
73                 {
74                       user->WriteNumeric(401, "%s %s :No such nick/channel",user->nick.c_str(), c->name.c_str());
75                       return CMD_FAILURE;
76                 }
77                 c->UserList(user);
78         }
79         else
80         {
81                 user->WriteNumeric(401, "%s %s :No such nick/channel",user->nick.c_str(), parameters[0].c_str());
82         }
83
84         return CMD_SUCCESS;
85 }
86
87 COMMAND_INIT(CommandNames)