diff options
author | Adam <Adam@anope.org> | 2010-11-30 03:02:33 -0500 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-12-12 19:37:02 -0500 |
commit | 0ba566491ea246fcc895862d0ef80bdf4ee43b4b (patch) | |
tree | 9852671d32476ddad58e264a8e074c41fef9f69f /modules/core/cs_kick.cpp | |
parent | 2a4d57a1cacd22084abea5dd21c87dc733a7b5bf (diff) |
Allowing adding hostmasks to channel access lists
Diffstat (limited to 'modules/core/cs_kick.cpp')
-rw-r--r-- | modules/core/cs_kick.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/modules/core/cs_kick.cpp b/modules/core/cs_kick.cpp index 8a2dd8b04..b829ce249 100644 --- a/modules/core/cs_kick.cpp +++ b/modules/core/cs_kick.cpp @@ -29,17 +29,19 @@ class CommandCSKick : public Command User *u = source.u; ChannelInfo *ci = source.ci; Channel *c = ci->c; - User *u2; - bool is_same = target.equals_ci(u->nick); + User *u2 = is_same ? u : finduser(target); + + ChanAccess *u_access = ci->GetAccess(u), *u2_access = ci->GetAccess(u2); + uint16 u_level = u_access ? u_access->level : 0, u2_level = u2_access ? u2_access->level : 0; if (!c) source.Reply(CHAN_X_NOT_IN_USE, chan.c_str()); - else if (is_same ? !(u2 = u) : !(u2 = finduser(target))) + else if (!u2) source.Reply(NICK_X_NOT_IN_USE, target.c_str()); else if (!is_same ? !check_access(u, ci, CA_KICK) : !check_access(u, ci, CA_KICKME)) source.Reply(ACCESS_DENIED); - else if (!is_same && (ci->HasFlag(CI_PEACE)) && get_access(u2, ci) >= get_access(u, ci)) + else if (!is_same && (ci->HasFlag(CI_PEACE)) && u2_level >= u_level) source.Reply(ACCESS_DENIED); else if (u2->IsProtected()) source.Reply(ACCESS_DENIED); |