2 * InspIRCd -- Internet Relay Chat Daemon
4 * Copyright (C) 2010 Daniel De Graaf <danieldg@inspircd.org>
6 * This file is part of InspIRCd. InspIRCd is free software: you can
7 * redistribute it and/or modify it under the terms of the GNU General Public
8 * License as published by the Free Software Foundation, version 2.
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
26 class CommandRConnect : public Command
28 SpanningTreeUtilities* Utils; /* Utility class */
30 CommandRConnect (Module* Callback, SpanningTreeUtilities* Util);
31 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
32 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters);
35 class CommandRSQuit : public Command
37 SpanningTreeUtilities* Utils; /* Utility class */
39 CommandRSQuit(Module* Callback, SpanningTreeUtilities* Util);
40 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
41 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters);
44 class CommandSVSJoin : public Command
47 CommandSVSJoin(Module* Creator) : Command(Creator, "SVSJOIN", 2) { flags_needed = FLAG_SERVERONLY; }
48 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
49 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters);
51 class CommandSVSPart : public Command
54 CommandSVSPart(Module* Creator) : Command(Creator, "SVSPART", 2) { flags_needed = FLAG_SERVERONLY; }
55 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
56 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters);
58 class CommandSVSNick : public Command
61 CommandSVSNick(Module* Creator) : Command(Creator, "SVSNICK", 3) { flags_needed = FLAG_SERVERONLY; }
62 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
63 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters);
65 class CommandMetadata : public Command
68 CommandMetadata(Module* Creator) : Command(Creator, "METADATA", 2) { flags_needed = FLAG_SERVERONLY; }
69 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
70 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
72 class CommandUID : public Command
75 CommandUID(Module* Creator) : Command(Creator, "UID", 10) { flags_needed = FLAG_SERVERONLY; }
76 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
77 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
79 class CommandOpertype : public Command
82 CommandOpertype(Module* Creator) : Command(Creator, "OPERTYPE", 1) { flags_needed = FLAG_SERVERONLY; }
83 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
84 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
86 class CommandFJoin : public Command
89 CommandFJoin(Module* Creator) : Command(Creator, "FJOIN", 3) { flags_needed = FLAG_SERVERONLY; }
90 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
91 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
92 /** Remove all modes from a channel, including statusmodes (+qaovh etc), simplemodes, parameter modes.
93 * This does not update the timestamp of the target channel, this must be done seperately.
95 void RemoveStatus(User* source, parameterlist ¶ms);
97 class CommandFMode : public Command
100 CommandFMode(Module* Creator) : Command(Creator, "FMODE", 3) { flags_needed = FLAG_SERVERONLY; }
101 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
102 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
104 class CommandFTopic : public Command
107 CommandFTopic(Module* Creator) : Command(Creator, "FTOPIC", 4) { flags_needed = FLAG_SERVERONLY; }
108 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
109 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
111 class CommandFHost : public Command
114 CommandFHost(Module* Creator) : Command(Creator, "FHOST", 1) { flags_needed = FLAG_SERVERONLY; }
115 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
116 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
118 class CommandFIdent : public Command
121 CommandFIdent(Module* Creator) : Command(Creator, "FIDENT", 1) { flags_needed = FLAG_SERVERONLY; }
122 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
123 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
125 class CommandFName : public Command
128 CommandFName(Module* Creator) : Command(Creator, "FNAME", 1) { flags_needed = FLAG_SERVERONLY; }
129 CmdResult Handle (const std::vector<std::string>& parameters, User *user);
130 RouteDescriptor GetRouting(User* user, const std::vector<std::string>& parameters) { return ROUTE_BROADCAST; }
133 class SpanningTreeCommands
136 CommandRConnect rconnect;
137 CommandRSQuit rsquit;
138 CommandSVSJoin svsjoin;
139 CommandSVSPart svspart;
140 CommandSVSNick svsnick;
141 CommandMetadata metadata;
143 CommandOpertype opertype;
146 CommandFTopic ftopic;
148 CommandFIdent fident;
150 SpanningTreeCommands(ModuleSpanningTree* module);