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
|
/* +------------------------------------+
* | Inspire Internet Relay Chat Daemon |
* +------------------------------------+
*
* InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev.
* E-mail:
* <brain@chatspike.net>
* <Craig@chatspike.net>
*
* Written by Craig Edwards, Craig McLure, and others.
* This program is free but copyrighted software; see
* the file COPYING for details.
*
* ---------------------------------------------------
*/
using namespace std;
#include <stdio.h>
#include "users.h"
#include "channels.h"
#include "modules.h"
/* $ModDesc: Sets (and unsets) modes on opers when they oper up */
class ModuleModesOnOper : public Module
{
private:
Server *Srv;
ConfigReader *Conf;
public:
ModuleModesOnOper(Server* Me)
: Module::Module(Me)
{
Srv = Me;
Conf = new ConfigReader;
}
void Implements(char* List)
{
List[I_OnOper] = 1;
}
virtual ~ModuleModesOnOper()
{
delete Conf;
}
virtual Version GetVersion()
{
return Version(1,0,0,1,VF_VENDOR);
}
virtual void OnOper(userrec* user, std::string opertype)
{
// whenever a user opers, go through the oper types, find their <type:modes>,
// and if they have one apply their modes. The mode string can contain +modes
// to add modes to the user or -modes to take modes from the user.
for (int j =0; j < Conf->Enumerate("type"); j++)
{
std::string typen = Conf->ReadValue("type","name",j);
if (!strcmp(typen.c_str(),user->oper))
{
std::string ThisOpersModes = Conf->ReadValue("type","modes",j);
char first = *(ThisOpersModes.c_str());
if ((first != '+') && (first != '-'))
ThisOpersModes = "+" + ThisOpersModes;
if (ThisOpersModes != "")
{
char* modes[2];
modes[0] = user->nick;
modes[1] = (char*)ThisOpersModes.c_str();
Srv->SendMode(modes,2,user);
}
break;
}
}
}
};
// stuff down here is the module-factory stuff. For basic modules you can ignore this.
class ModuleModesOnOperFactory : public ModuleFactory
{
public:
ModuleModesOnOperFactory()
{
}
~ModuleModesOnOperFactory()
{
}
virtual Module * CreateModule(Server* Me)
{
return new ModuleModesOnOper(Me);
}
};
extern "C" void * init_module( void )
{
return new ModuleModesOnOperFactory;
}
|