diff options
author | Adam <Adam@anope.org> | 2013-04-10 22:26:40 -0500 |
---|---|---|
committer | Adam <Adam@anope.org> | 2013-04-10 22:26:40 -0500 |
commit | 207c46c871e85b55ae66acc456c6bc412c0c79f9 (patch) | |
tree | 27b07dc9d1e0ee068872ec7841920eea9b846b65 /modules/extra/cs_statusupdate.cpp | |
parent | 957cb2bf93d77a5ebb97d945b0656bd1e7bec164 (diff) |
Move some of the modules in extras/ that arent really extra out of extras. Mark our modules as VENDOR and allow modules to have multple types.
Diffstat (limited to 'modules/extra/cs_statusupdate.cpp')
-rw-r--r-- | modules/extra/cs_statusupdate.cpp | 67 |
1 files changed, 0 insertions, 67 deletions
diff --git a/modules/extra/cs_statusupdate.cpp b/modules/extra/cs_statusupdate.cpp deleted file mode 100644 index 934b928d1..000000000 --- a/modules/extra/cs_statusupdate.cpp +++ /dev/null @@ -1,67 +0,0 @@ -/* - * (C) 2003-2013 Anope Team - * Contact us at team@anope.org - * - * Please read COPYING and README for further details. - */ - -#include "module.h" - -class StatusUpdate : public Module -{ - public: - StatusUpdate(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, SUPPORTED) - { - this->SetAuthor("Anope"); - - Implementation i[] = { I_OnAccessAdd, I_OnAccessDel }; - ModuleManager::Attach(i, this, sizeof(i) / sizeof(Implementation)); - } - - void OnAccessAdd(ChannelInfo *ci, CommandSource &, ChanAccess *access) anope_override - { - if (ci->c) - for (Channel::ChanUserList::iterator it = ci->c->users.begin(), it_end = ci->c->users.end(); it != it_end; ++it) - { - User *user = it->second->user; - - if (user->server != Me && access->Matches(user, user->Account())) - { - for (unsigned i = 0; i < ModeManager::GetStatusChannelModesByRank().size(); ++i) - { - ChannelModeStatus *cms = ModeManager::GetStatusChannelModesByRank()[i]; - if (!access->HasPriv("AUTO" + cms->name)) - ci->c->RemoveMode(NULL, cms, user->GetUID()); - } - ci->c->SetCorrectModes(user, true, false); - } - } - } - - void OnAccessDel(ChannelInfo *ci, CommandSource &, ChanAccess *access) anope_override - { - if (ci->c) - for (Channel::ChanUserList::iterator it = ci->c->users.begin(), it_end = ci->c->users.end(); it != it_end; ++it) - { - User *user = it->second->user; - - if (user->server != Me && access->Matches(user, user->Account())) - { - /* Get user's current access and remove the entry about to be deleted */ - AccessGroup ag = ci->AccessFor(user); - AccessGroup::iterator iter = std::find(ag.begin(), ag.end(), access); - if (iter != ag.end()) - ag.erase(iter); - - for (unsigned i = 0; i < ModeManager::GetStatusChannelModesByRank().size(); ++i) - { - ChannelModeStatus *cms = ModeManager::GetStatusChannelModesByRank()[i]; - if (!ag.HasPriv("AUTO" + cms->name)) - ci->c->RemoveMode(NULL, cms, user->GetUID()); - } - } - } - } -}; - -MODULE_INIT(StatusUpdate) |