/* * InspIRCd -- Internet Relay Chat Daemon * * Copyright (C) 2012-2014 Attila Molnar * Copyright (C) 2009 Daniel De Graaf * * This file is part of InspIRCd. InspIRCd is free software: you can * redistribute it and/or modify it under the terms of the GNU General Public * License as published by the Free Software Foundation, version 2. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more * details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #pragma once class CoreExport Membership : public Extensible, public intrusive_list_node { public: User* const user; Channel* const chan; // mode list, sorted by prefix rank, higest first std::string modes; Membership(User* u, Channel* c) : user(u), chan(c) {} inline bool hasMode(char m) const { return modes.find(m) != std::string::npos; } unsigned int getRank(); /** Add a prefix character to a user. * Only the core should call this method, usually from * within the mode parser or when the first user joins * the channel (to grant the default privs to them) * @param mh The mode handler of the prefix mode to associate * @param adding True if adding the prefix, false when removing * @return True if a change was made */ bool SetPrefix(PrefixMode* mh, bool adding); /** Get the highest prefix this user has on the channel * @return A character containing the highest prefix. * If the user has no prefix, 0 is returned. If the user has multiple prefixes, * the highest is returned. If you do not recognise the prefix character you * can get, you can deal with it in a 'proportional' manner compared to known * prefixes, using GetPrefixValue(). */ char GetPrefixChar() const; }; template class InviteBase { protected: intrusive_list invites; public: void ClearInvites(); friend class Invitation; }; class CoreExport Invitation : public intrusive_list_node, public intrusive_list_node { Invitation(Channel* c, LocalUser* u, time_t timeout) : user(u), chan(c), expiry(timeout) {} public: LocalUser* const user; Channel* const chan; time_t expiry; ~Invitation(); static void Create(Channel* c, LocalUser* u, time_t timeout); static Invitation* Find(Channel* c, LocalUser* u, bool check_expired = true); }; typedef intrusive_list InviteList; template inline void InviteBase::ClearInvites() { for (typename intrusive_list::iterator i = invites.begin(); i != invites.end(); ) { Invitation* inv = *i; ++i; delete inv; } }