2 * InspIRCd -- Internet Relay Chat Daemon
4 * Copyright (C) 2008 Robin Burchell <robin+git@viroteck.net>
5 * Copyright (C) 2007 Dennis Friis <peavey@inspircd.org>
6 * Copyright (C) 2006 Craig Edwards <craigedwards@brainbox.cc>
8 * This file is part of InspIRCd. InspIRCd is free software: you can
9 * redistribute it and/or modify it under the terms of the GNU General Public
10 * License as published by the Free Software Foundation, version 2.
12 * This program is distributed in the hope that it will be useful, but WITHOUT
13 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
29 class ModeChannelBan : public ListModeBase
33 : ListModeBase(NULL, "ban", 'b', "End of channel ban list", 367, 368, true, "maxbans")
40 class ModeChannelKey : public ParamMode<ModeChannelKey, LocalStringExt>
44 ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding);
45 void SerializeParam(Channel* chan, const std::string* key, std::string& out);
46 ModeAction OnSet(User* source, Channel* chan, std::string& param);
51 class ModeChannelLimit : public ParamMode<ModeChannelLimit, LocalIntExt>
55 bool ResolveModeConflict(std::string &their_param, const std::string &our_param, Channel* channel);
56 void SerializeParam(Channel* chan, intptr_t n, std::string& out);
57 ModeAction OnSet(User* source, Channel* channel, std::string& parameter);
62 class ModeChannelOp : public PrefixMode
66 : PrefixMode(NULL, "op", 'o', OP_VALUE, '@')
68 levelrequired = OP_VALUE;
74 class ModeChannelVoice : public PrefixMode
78 : PrefixMode(NULL, "voice", 'v', VOICE_VALUE, '+')
80 levelrequired = HALFOP_VALUE;
86 class ModeUserServerNoticeMask : public ModeHandler
88 /** Process a snomask modifier string, e.g. +abc-de
89 * @param user The target user
90 * @param input A sequence of notice mask characters
91 * @return The cleaned mode sequence which can be output,
92 * e.g. in the above example if masks c and e are not
93 * valid, this function will return +ab-d
95 std::string ProcessNoticeMasks(User* user, const std::string& input);
98 ModeUserServerNoticeMask();
99 ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding);
100 void OnParameterMissing(User* user, User* dest, Channel* channel);
102 /** Create a displayable mode string of the snomasks set on a given user
103 * @param user The user whose notice masks to format
104 * @return The notice mask character sequence
106 std::string GetUserParameter(User* user);
111 class ModeUserOperator : public ModeHandler
115 ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding);