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 ModeChannelInviteOnly : public SimpleChannelModeHandler
43 ModeChannelInviteOnly() : SimpleChannelModeHandler(NULL, "inviteonly", 'i')
50 class ModeChannelKey : public ParamMode<ModeChannelKey, LocalStringExt>
54 ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding);
55 void SerializeParam(Channel* chan, const std::string* key, std::string& out);
56 ModeAction OnSet(User* source, Channel* chan, std::string& param);
61 class ModeChannelLimit : public ParamMode<ModeChannelLimit, LocalIntExt>
65 bool ResolveModeConflict(std::string &their_param, const std::string &our_param, Channel* channel);
66 void SerializeParam(Channel* chan, intptr_t n, std::string& out);
67 ModeAction OnSet(User* source, Channel* channel, std::string& parameter);
72 class ModeChannelModerated : public SimpleChannelModeHandler
75 ModeChannelModerated() : SimpleChannelModeHandler(NULL, "moderated", 'm')
82 class ModeChannelNoExternal : public SimpleChannelModeHandler
85 ModeChannelNoExternal() : SimpleChannelModeHandler(NULL, "noextmsg", 'n')
92 class ModeChannelOp : public PrefixMode
100 class ModeChannelPrivate : public SimpleChannelModeHandler
103 ModeChannelPrivate() : SimpleChannelModeHandler(NULL, "private", 'p')
110 class ModeChannelSecret : public SimpleChannelModeHandler
113 ModeChannelSecret() : SimpleChannelModeHandler(NULL, "secret", 's')
120 class ModeChannelTopicOps : public SimpleChannelModeHandler
123 ModeChannelTopicOps() : SimpleChannelModeHandler(NULL, "topiclock", 't')
130 class ModeChannelVoice : public PrefixMode
138 class ModeUserInvisible : public SimpleUserModeHandler
141 ModeUserInvisible() : SimpleUserModeHandler(NULL, "invisible", 'i')
148 class ModeUserServerNoticeMask : public ModeHandler
150 /** Process a snomask modifier string, e.g. +abc-de
151 * @param user The target user
152 * @param input A sequence of notice mask characters
153 * @return The cleaned mode sequence which can be output,
154 * e.g. in the above example if masks c and e are not
155 * valid, this function will return +ab-d
157 std::string ProcessNoticeMasks(User* user, const std::string& input);
160 ModeUserServerNoticeMask();
161 ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding);
162 void OnParameterMissing(User* user, User* dest, Channel* channel);
164 /** Create a displayable mode string of the snomasks set on a given user
165 * @param user The user whose notice masks to format
166 * @return The notice mask character sequence
168 std::string GetUserParameter(User* user);
173 class ModeUserOperator : public ModeHandler
177 ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding);