]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_mlock.cpp
Convert WriteNumeric() calls to pass the parameters of the numeric as method parameters
[user/henk/code/inspircd.git] / src / modules / m_mlock.cpp
index 8ad062aea348b6165d97cb34cacd475e3f8ffedb..d3ab5b9fd2af0700fb6b26e2e95cad0b59183020 100644 (file)
@@ -23,13 +23,10 @@ class ModuleMLock : public Module
 {
        StringExtItem mlock;
 
-public:
-       ModuleMLock() : mlock("mlock", this) {};
-
-       void init() CXX11_OVERRIDE
+ public:
+       ModuleMLock()
+               : mlock("mlock", ExtensionItem::EXT_CHANNEL, this)
        {
-               ServerInstance->Modules->Attach(I_OnPreMode, this);
-               ServerInstance->Modules->AddService(this->mlock);
        }
 
        Version GetVersion() CXX11_OVERRIDE
@@ -37,12 +34,7 @@ public:
                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<std::string>& parameters) CXX11_OVERRIDE
+       ModResult OnRawMode(User* source, Channel* channel, ModeHandler* mh, const std::string& parameter, bool adding)
        {
                if (!channel)
                        return MOD_RES_PASSTHRU;
@@ -54,11 +46,11 @@ public:
                if (!mlock_str)
                        return MOD_RES_PASSTHRU;
 
-               std::string::size_type p = parameters[1].find_first_of(*mlock_str);
+               const char mode = mh->GetModeChar();
+               std::string::size_type p = mlock_str->find(mode);
                if (p != std::string::npos)
                {
-                       source->WriteNumeric(742, "%s %c %s :MODE cannot be set due to channel having an active MLOCK restriction policy",
-                                            channel->name.c_str(), parameters[1][p], mlock_str->c_str());
+                       source->WriteNumeric(742, channel->name, mode, *mlock_str, "MODE cannot be set due to channel having an active MLOCK restriction policy");
                        return MOD_RES_DENY;
                }