1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
using namespace std;
#include "users.h"
#include "channels.h"
#include "modules.h"
#include <string>
#include "helperfuncs.h"
#include "inspircd.h"
/* $ModDesc: Gives each oper type a 'level', cannot kill opers 'above' your level. */
class ModuleOperLevels : public Module
{
private:
ConfigReader* conf;
public:
ModuleOperLevels(InspIRCd* Me)
: Module::Module(Me)
{
conf = new ConfigReader(ServerInstance);
}
virtual ~ModuleOperLevels()
{
DELETE(conf);
}
void Implements(char* List)
{
List[I_OnRehash] = List[I_OnKill] = 1;
}
virtual void OnRehash(const std::string ¶meter)
{
DELETE(conf);
conf = new ConfigReader(ServerInstance);
}
virtual Version GetVersion()
{
return Version(1,0,0,1,VF_VENDOR);
}
virtual int OnKill(userrec* source, userrec* dest, const std::string &reason)
{
long dest_level = 0,source_level = 0;
// oper killing an oper?
if (*dest->oper)
{
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;
}
}
if (dest_level > source_level)
{
ServerInstance->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());
dest->WriteServ("NOTICE %s :Oper %s attempted to /kill you!",dest->nick,source->nick);
source->WriteServ("481 %s :Permission Denied- Oper %s is a higher level than you",source->nick,dest->nick);
return 1;
}
}
return 0;
}
};
class ModuleOperLevelsFactory : public ModuleFactory
{
public:
ModuleOperLevelsFactory()
{
}
~ModuleOperLevelsFactory()
{
}
virtual Module * CreateModule(InspIRCd* Me)
{
return new ModuleOperLevels(Me);
}
};
extern "C" void * init_module( void )
{
return new ModuleOperLevelsFactory;
}
|