]> git.netwichtig.de Git - user/henk/code/inspircd.git/blob - src/commands/cmd_commands.cpp
m_callerid Use std::find() where possible
[user/henk/code/inspircd.git] / src / commands / cmd_commands.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_COMMANDS_H
24 #define CMD_COMMANDS_H
25
26 // include the common header files
27
28 #include "users.h"
29 #include "channels.h"
30
31 /** Handle /COMMANDS. 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 CommandCommands : public Command
37 {
38  public:
39         /** Constructor for commands.
40          */
41         CommandCommands ( Module* parent) : Command(parent,"COMMANDS",0,0) { }
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 /COMMANDS
55  */
56 CmdResult CommandCommands::Handle (const std::vector<std::string>&, User *user)
57 {
58         std::vector<std::string> list;
59         list.reserve(ServerInstance->Parser->cmdlist.size());
60         for (Commandtable::iterator i = ServerInstance->Parser->cmdlist.begin(); i != ServerInstance->Parser->cmdlist.end(); i++)
61         {
62                 Module* src = i->second->creator;
63                 char buffer[MAXBUF];
64                 snprintf(buffer, MAXBUF, ":%s %03d %s :%s %s %d %d",
65                         ServerInstance->Config->ServerName.c_str(), RPL_COMMANDS, user->nick.c_str(),
66                         i->second->name.c_str(), src->ModuleSourceFile.c_str(),
67                         i->second->min_params, i->second->Penalty);
68                 list.push_back(buffer);
69         }
70         sort(list.begin(), list.end());
71         for(unsigned int i=0; i < list.size(); i++)
72                 user->Write(list[i]);
73         user->WriteNumeric(RPL_COMMANDSEND, "%s :End of COMMANDS list",user->nick.c_str());
74         return CMD_SUCCESS;
75 }
76
77 COMMAND_INIT(CommandCommands)