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
|
/* +------------------------------------+
* | Inspire Internet Relay Chat Daemon |
* +------------------------------------+
*
* InspIRCd: (C) 2002-2010 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"
#include "u_listmode.h"
/* $ModDesc: Provides support for the +w channel mode, autoop list */
/** Handles +w channel mode
*/
class AutoOpList : public ListModeBase
{
public:
AutoOpList(Module* Creator) : ListModeBase(Creator, "autoop", 'w', "End of Channel Access List", 910, 911, true)
{
levelrequired = OP_VALUE;
}
ModResult AccessCheck(User* source, Channel* channel, std::string ¶meter, bool adding)
{
std::string::size_type pos = parameter.find(':');
if (pos == 0 || pos == std::string::npos)
return adding ? MOD_RES_DENY : MOD_RES_PASSTHRU;
unsigned int mylevel = channel->GetPrefixValue(source);
while (pos > 0)
{
pos--;
ModeHandler* mh = ServerInstance->Modes->FindMode(parameter[pos], MODETYPE_CHANNEL);
if (adding && !mh)
return MOD_RES_DENY;
else if (!mh)
continue;
std::string dummy;
if (mh->AccessCheck(source, channel, dummy, true) == MOD_RES_DENY)
return MOD_RES_DENY;
if (mh->GetLevelRequired() > mylevel)
return MOD_RES_DENY;
}
return MOD_RES_PASSTHRU;
}
};
class ModuleAutoOp : public Module
{
AutoOpList mh;
public:
ModuleAutoOp() : mh(this)
{
ServerInstance->Modules->AddService(mh);
mh.DoImplements(this);
Implementation list[] = { I_OnUserPreJoin, };
ServerInstance->Modules->Attach(list, this, 1);
}
ModResult OnUserPreJoin(User *user, Channel *chan, const char *cname, std::string &privs, const std::string &keygiven)
{
if (!chan)
return MOD_RES_PASSTHRU;
modelist* list = mh.extItem.get(chan);
if (list)
{
for (modelist::iterator it = list->begin(); it != list->end(); it++)
{
std::string::size_type colon = it->mask.find(':');
if (colon == std::string::npos)
continue;
if (chan->CheckBan(user, it->mask.substr(colon+1)))
privs += it->mask.substr(0, colon);
}
}
return MOD_RES_PASSTHRU;
}
void OnCleanup(int target_type, void* item)
{
mh.DoCleanup(target_type, item);
}
void OnSyncChannel(Channel* chan, Module* proto, void* opaque)
{
mh.DoSyncChannel(chan, proto, opaque);
}
void OnRehash(User* user)
{
mh.DoRehash();
}
Version GetVersion()
{
return Version("Provides support for the +w channel mode", VF_VENDOR);
}
};
MODULE_INIT(ModuleAutoOp)
|