]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_operlevels.cpp
m_spanningtree Remove unneeded #includes
[user/henk/code/inspircd.git] / src / modules / m_operlevels.cpp
index 7e28f6c21f2fad732df147dc16c84feb79f9fa98..7f94b8a0d856dff4be81bcd5935556dde8c9a6bb 100644 (file)
@@ -27,7 +27,7 @@
 class ModuleOperLevels : public Module
 {
        public:
-               ModuleOperLevels()
+               void init()
                {
                        ServerInstance->Modules->Attach(I_OnKill, this);
                }
@@ -40,10 +40,13 @@ class ModuleOperLevels : public Module
                virtual ModResult OnKill(User* source, User* dest, const std::string &reason)
                {
                        // oper killing an oper?
-                       if (IS_OPER(dest) && IS_OPER(source))
+                       if (dest->IsOper() && source->IsOper())
                        {
-                               long dest_level = atol(dest->oper->getConfig("level").c_str());
-                               long source_level = atol(source->oper->getConfig("level").c_str());
+                               std::string level = dest->oper->getConfig("level");
+                               long dest_level = atol(level.c_str());
+                               level = source->oper->getConfig("level");
+                               long source_level = atol(level.c_str());
+
                                if (dest_level > source_level)
                                {
                                        if (IS_LOCAL(source)) ServerInstance->SNO->WriteGlobalSno('a', "Oper %s (level %ld) attempted to /kill a higher oper: %s (level %ld): Reason: %s",source->nick.c_str(),source_level,dest->nick.c_str(),dest_level,reason.c_str());
@@ -57,4 +60,3 @@ class ModuleOperLevels : public Module
 };
 
 MODULE_INIT(ModuleOperLevels)
-