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
|
using namespace std;
#include "users.h"
#include "channels.h"
#include "modules.h"
#include <string>
#include "helperfuncs.h"
/* $ModDesc: Gives each oper type a 'level', cannot kill opers 'above' your level. */
Server *Srv;
class ModuleOperLevels : public Module
{
private:
ConfigReader* conf;
public:
ModuleOperLevels(Server* Me)
: Module::Module(Me)
{
Srv = Me;
conf = new ConfigReader;
}
virtual ~ModuleOperLevels()
{
delete conf;
}
void Implements(char* List)
{
List[I_OnRehash] = List[I_OnKill] = 1;
}
virtual void OnRehash(std::string parameter)
{
delete conf;
conf = new ConfigReader;
}
virtual Version GetVersion()
{
return Version(1,0,0,1,VF_VENDOR);
}
virtual int OnKill(userrec* source, userrec* dest, std::string reason)
{
long dest_level = 0,source_level = 0;
// oper killing an oper?
if (strchr(dest->modes,'o'))
{
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)
{
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;
}
}
return 0;
}
};
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;
}
|