]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_samode.cpp
Make end of netburst SNOMASK REMOTELINK unless servers are directly linked [jackmcbarn]
[user/henk/code/inspircd.git] / src / modules / m_samode.cpp
index 58419934507721c88b1dfe532cc9a32f63b30225..92894f5b80bacab83574a2f412bf8bf27008484f 100644 (file)
@@ -21,9 +21,9 @@ class CommandSamode : public Command
 {
  public:
        bool active;
-       CommandSamode (InspIRCd* Instance, Module* Creator) : Command(Instance, Creator,"SAMODE", "o", 2, false, 0)
+       CommandSamode(Module* Creator) : Command(Creator,"SAMODE", 2)
        {
-               syntax = "<target> <modes> {<mode-parameters>}";
+               flags_needed = 'o'; Penalty = 0; syntax = "<target> <modes> {<mode-parameters>}";
                active = false;
        }
 
@@ -34,7 +34,7 @@ class CommandSamode : public Command
                if (ServerInstance->Modes->GetLastParse().length())
                        ServerInstance->SNO->WriteGlobalSno('a', std::string(user->nick) + " used SAMODE: " +ServerInstance->Modes->GetLastParse());
                this->active = false;
-               return CMD_LOCALONLY;
+               return CMD_SUCCESS;
        }
 };
 
@@ -43,22 +43,22 @@ class ModuleSaMode : public Module
        CommandSamode cmd;
  public:
        ModuleSaMode(InspIRCd* Me)
-               : Module(Me), cmd(Me, this)
+               : Module(Me), cmd(this)
        {
                ServerInstance->AddCommand(&cmd);
-               ServerInstance->Modules->Attach(I_OnAccessCheck, this);
+               ServerInstance->Modules->Attach(I_OnPreMode, this);
        }
 
-       virtual ~ModuleSaMode()
+       ~ModuleSaMode()
        {
        }
 
-       virtual Version GetVersion()
+       Version GetVersion()
        {
                return Version("$Id$", VF_VENDOR, API_VERSION);
        }
 
-       virtual ModResult OnAccessCheck(User* source,User* dest,Channel* channel,int access_type)
+       ModResult OnPreMode(User* source,User* dest,Channel* channel, const std::vector<std::string>& parameters)
        {
                if (cmd.active)
                        return MOD_RES_ALLOW;
@@ -68,7 +68,7 @@ class ModuleSaMode : public Module
        void Prioritize()
        {
                Module *override = ServerInstance->Modules->Find("m_override.so");
-               ServerInstance->Modules->SetPriority(this, I_OnAccessCheck, PRIORITY_BEFORE, &override);
+               ServerInstance->Modules->SetPriority(this, I_OnPreMode, PRIORITY_BEFORE, &override);
        }
 };