-using namespace std;
-
-#include "users.h"
-#include "channels.h"
-#include "modules.h"
-#include <string>
-#include "helperfuncs.h"
+/* +------------------------------------+
+ * | Inspire Internet Relay Chat Daemon |
+ * +------------------------------------+
+ *
+ * InspIRCd: (C) 2002-2009 InspIRCd Development Team
+ * See: http://wiki.inspircd.org/Credits
+ *
+ * This program is free but copyrighted software; see
+ * the file COPYING for details.
+ *
+ * ---------------------------------------------------
+ */
+
+#include "inspircd.h"
/* $ModDesc: Gives each oper type a 'level', cannot kill opers 'above' your level. */
-
class ModuleOperLevels : public Module
{
-
- private:
-
- Server* Srv;
- ConfigReader* conf;
-
public:
-
- ModuleOperLevels(Server* Me)
- : Module::Module(Me)
+ ModuleOperLevels()
{
-
- Srv = Me;
- conf = new ConfigReader;
+ Implementation eventlist[] = { I_OnRehash, I_OnKill };
+ ServerInstance->Modules->Attach(eventlist, this, 2);
}
virtual ~ModuleOperLevels()
{
- delete conf;
}
- void Implements(char* List)
- {
- List[I_OnRehash] = List[I_OnKill] = 1;
- }
- virtual void OnRehash(const std::string ¶meter)
+ virtual void OnRehash(User* user)
{
- delete conf;
- conf = new ConfigReader;
}
virtual Version GetVersion()
{
- return Version(1,0,0,1,VF_VENDOR);
+ return Version("Gives each oper type a 'level', cannot kill opers 'above' your level.", VF_VENDOR);
}
- virtual int OnKill(userrec* source, userrec* dest, const std::string &reason)
+ virtual ModResult OnKill(User* source, User* dest, const std::string &reason)
{
- long dest_level = 0,source_level = 0;
// oper killing an oper?
- if (*dest->oper)
+ if (IS_OPER(dest) && IS_OPER(source))
{
- for (int j =0; j < conf->Enumerate("type"); j++)
- {
- std::string typen = conf->ReadValue("type","name",j);
- if (!strcmp(typen.c_str(),dest->oper))
- {
- dest_level = conf->ReadInteger("type","level",j,true);
- break;
- }
- }
- for (int k =0; k < conf->Enumerate("type"); k++)
- {
- std::string typen = conf->ReadValue("type","name",k);
- if (!strcmp(typen.c_str(),source->oper))
- {
- source_level = conf->ReadInteger("type","level",k,true);
- break;
- }
- }
+ TagIndex::iterator dest_type = ServerInstance->Config->opertypes.find(dest->oper);
+ TagIndex::iterator src_type = ServerInstance->Config->opertypes.find(source->oper);
+
+ if (dest_type == ServerInstance->Config->opertypes.end())
+ return MOD_RES_PASSTHRU;
+ if (src_type == ServerInstance->Config->opertypes.end())
+ return MOD_RES_PASSTHRU;
+
+ long dest_level = dest_type->second->getInt("level");
+ long source_level = src_type->second->getInt("level");
if (dest_level > source_level)
{
- WriteOpers("Oper %s (level %d) attempted to /kill a higher oper: %s (level %d): Reason: %s",source->nick,source_level,dest->nick,dest_level,reason.c_str());
- WriteServ(dest->fd,"NOTICE %s :Oper %s attempted to /kill you!",dest->nick,source->nick);
- WriteServ(source->fd,"481 %s :Permission Denied- Oper %s is a higher level than you",source->nick,dest->nick);
- return 1;
+ 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());
+ dest->WriteServ("NOTICE %s :*** Oper %s attempted to /kill you!",dest->nick.c_str(),source->nick.c_str());
+ source->WriteNumeric(ERR_NOPRIVILEGES, "%s :Permission Denied - Oper %s is a higher level than you",source->nick.c_str(),dest->nick.c_str());
+ return MOD_RES_DENY;
}
}
- return 0;
+ return MOD_RES_PASSTHRU;
}
};
-class ModuleOperLevelsFactory : public ModuleFactory
-{
- public:
- ModuleOperLevelsFactory()
- {
- }
-
- ~ModuleOperLevelsFactory()
- {
- }
-
- virtual Module * CreateModule(Server* Me)
- {
- return new ModuleOperLevels(Me);
- }
-
-};
-
-extern "C" void * init_module( void )
-{
- return new ModuleOperLevelsFactory;
-}
+MODULE_INIT(ModuleOperLevels)