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
|
// operjoin module by typobox43
using namespace std;
#include "users.h"
#include "channels.h"
#include "modules.h"
#include "helperfuncs.h"
/* $ModDesc: Forces opers to join a specified channel on oper-up */
class ModuleOperjoin : public Module
{
private:
std::string operChan;
ConfigReader* conf;
Server* Srv;
int tokenize(const string &str, std::vector<std::string> &tokens)
{
// skip delimiters at beginning.
string::size_type lastPos = str.find_first_not_of(",", 0);
// find first "non-delimiter".
string::size_type pos = str.find_first_of(",", lastPos);
while (string::npos != pos || string::npos != lastPos)
{
// found a token, add it to the vector.
tokens.push_back(str.substr(lastPos, pos - lastPos));
// skip delimiters. Note the "not_of"
lastPos = str.find_first_not_of(",", pos);
// find next "non-delimiter"
pos = str.find_first_of(",", lastPos);
}
return tokens.size();
}
public:
ModuleOperjoin(Server* Me)
: Module::Module(Me)
{
Srv = Me;
conf = new ConfigReader;
operChan = conf->ReadValue("operjoin", "channel", 0);
}
void Implements(char* List)
{
List[I_OnPostOper] = List[I_OnRehash] = 1;
}
virtual void OnRehash(const std::string ¶meter)
{
DELETE(conf);
conf = new ConfigReader;
}
virtual ~ModuleOperjoin()
{
DELETE(conf);
}
virtual Version GetVersion()
{
return Version(1,0,0,1,VF_VENDOR);
}
virtual void OnPostOper(userrec* user, const std::string &opertype)
{
if(operChan != "")
{
std::vector<std::string> operChans;
tokenize(operChan,operChans);
for(std::vector<std::string>::iterator it = operChans.begin(); it != operChans.end(); it++)
{
Srv->JoinUserToChannel(user,(*it),"");
}
}
}
};
class ModuleOperjoinFactory : public ModuleFactory
{
public:
ModuleOperjoinFactory()
{
}
~ModuleOperjoinFactory()
{
}
virtual Module * CreateModule(Server* Me)
{
return new ModuleOperjoin(Me);
}
};
extern "C" void * init_module( void )
{
return new ModuleOperjoinFactory;
}
|