X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fmodules%2Fm_mlock.cpp;h=85787ae9644b2e6c2c21983141c9a8fb3ceea46c;hb=ac0d5abaace6521643b213423bf57625abe9dd41;hp=45ad7453e2532277b5b1a2cc057971def5ebd65c;hpb=663f0620bea4dc1e64ec640992f4d511ae1ef97b;p=user%2Fhenk%2Fcode%2Finspircd.git
diff --git a/src/modules/m_mlock.cpp b/src/modules/m_mlock.cpp
index 45ad7453e..85787ae96 100644
--- a/src/modules/m_mlock.cpp
+++ b/src/modules/m_mlock.cpp
@@ -16,53 +16,52 @@
* along with this program. If not, see .
*/
+
#include "inspircd.h"
-class ModuleMLock : public Module {
-private:
- StringExtItem mlock;
+enum
+{
+ // From Charybdis.
+ ERR_MLOCKRESTRICTED = 742
+};
-public:
- ModuleMLock() : mlock("mlock", this) {};
+class ModuleMLock : public Module
+{
+ StringExtItem mlock;
- void init()
+ public:
+ ModuleMLock()
+ : mlock("mlock", ExtensionItem::EXT_CHANNEL, this)
{
- Implementation eventlist[] = { I_OnPreMode };
- ServerInstance->Modules->Attach(eventlist, this, 1);
}
- Version GetVersion()
+ Version GetVersion() CXX11_OVERRIDE
{
return Version("Implements the ability to have server-side MLOCK enforcement.", VF_VENDOR);
}
- void Prioritize()
- {
- ServerInstance->Modules->SetPriority(this, I_OnPreMode, PRIORITY_FIRST);
- }
-
- ModResult OnPreMode(User* source, User* dest, Channel* channel, const std::vector& parameters)
+ ModResult OnRawMode(User* source, Channel* channel, ModeHandler* mh, const std::string& parameter, bool adding) CXX11_OVERRIDE
{
if (!channel)
return MOD_RES_PASSTHRU;
+ if (!IS_LOCAL(source))
+ return MOD_RES_PASSTHRU;
+
std::string *mlock_str = mlock.get(channel);
- if (!mlock_str || mlock_str->empty())
+ if (!mlock_str)
return MOD_RES_PASSTHRU;
- for (const char *modes = parameters[1].c_str(); *modes; modes++)
+ const char mode = mh->GetModeChar();
+ std::string::size_type p = mlock_str->find(mode);
+ if (p != std::string::npos)
{
- if (mlock_str->find(*modes))
- {
- source->WriteNumeric(742, "%s %c %s :MODE cannot be set due to channel having an active MLOCK restriction policy",
- channel->name.c_str(), *modes, mlock_str->c_str());
- return MOD_RES_DENY;
- }
+ source->WriteNumeric(ERR_MLOCKRESTRICTED, channel->name, mode, *mlock_str, "MODE cannot be set due to channel having an active MLOCK restriction policy");
+ return MOD_RES_DENY;
}
return MOD_RES_PASSTHRU;
}
-
};
MODULE_INIT(ModuleMLock)