diff options
author | Adam <Adam@anope.org> | 2010-07-15 22:55:02 -0400 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-07-15 22:55:02 -0400 |
commit | a22f8d3b2de88b9bb6f80f0c2780846ae23ab389 (patch) | |
tree | a2fdf570868896a787df8a1169951b0028e68d6b /modules/core/cs_ban.cpp | |
parent | 43b1e43afb85639485e36d24da351dc0f121be6e (diff) |
Moved some files and diretories around, made cmake skip files it knows it can't compile because of missing dependices.
Diffstat (limited to 'modules/core/cs_ban.cpp')
-rw-r--r-- | modules/core/cs_ban.cpp | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/modules/core/cs_ban.cpp b/modules/core/cs_ban.cpp new file mode 100644 index 000000000..17fbc1946 --- /dev/null +++ b/modules/core/cs_ban.cpp @@ -0,0 +1,111 @@ +/* ChanServ core functions + * + * (C) 2003-2010 Anope Team + * Contact us at team@anope.org + * + * Please read COPYING and README for further details. + * + * Based on the original code of Epona by Lara. + * Based on the original code of Services by Andy Church. + */ + +/*************************************************************************/ + +#include "module.h" + +class CommandCSBan : public Command +{ + public: + CommandCSBan(const ci::string &cname) : Command(cname, 2, 3) + { + } + + CommandReturn Execute(User *u, const std::vector<ci::string> ¶ms) + { + const char *chan = params[0].c_str(); + const char *target = params[1].c_str(); + const char *reason = NULL; + + if (params.size() > 2) + reason = params[2].c_str(); + + Channel *c = findchan(chan); + ChannelInfo *ci; + User *u2; + + int is_same; + + if (!reason) + reason = "Requested"; + + is_same = !stricmp(target, u->nick.c_str()); + + if (c) + ci = c->ci; + + if (!c) + notice_lang(Config.s_ChanServ, u, CHAN_X_NOT_IN_USE, chan); + else if (is_same ? !(u2 = u) : !(u2 = finduser(target))) + notice_lang(Config.s_ChanServ, u, NICK_X_NOT_IN_USE, target); + else if (!is_same ? !check_access(u, ci, CA_BAN) : !check_access(u, ci, CA_BANME)) + notice_lang(Config.s_ChanServ, u, ACCESS_DENIED); + else if (!is_same && (ci->HasFlag(CI_PEACE)) && (get_access(u2, ci) >= get_access(u, ci))) + notice_lang(Config.s_ChanServ, u, ACCESS_DENIED); + /* + * Dont ban/kick the user on channels where he is excepted + * to prevent services <-> server wars. + */ + else if (ModeManager::FindChannelModeByName(CMODE_EXCEPT) && is_excepted(ci, u2)) + notice_lang(Config.s_ChanServ, u, CHAN_EXCEPTED, u2->nick.c_str(), ci->name.c_str()); + else if (u2->IsProtected()) + notice_lang(Config.s_ChanServ, u, ACCESS_DENIED); + else + { + char mask[BUFSIZE]; + + get_idealban(ci, u2, mask, sizeof(mask)); + c->SetMode(NULL, CMODE_BAN, mask); + + /* We still allow host banning while not allowing to kick */ + if (!c->FindUser(u2)) + return MOD_CONT; + + if (ci->HasFlag(CI_SIGNKICK) || (ci->HasFlag(CI_SIGNKICK_LEVEL) && !check_access(u, ci, CA_SIGNKICK))) + c->Kick(whosends(ci), u2, "%s (%s)", reason, u->nick.c_str()); + else + c->Kick(whosends(ci), u2, "%s", reason); + } + + return MOD_CONT; + } + + bool OnHelp(User *u, const ci::string &subcommand) + { + notice_help(Config.s_ChanServ, u, CHAN_HELP_BAN); + return true; + } + + void OnSyntaxError(User *u, const ci::string &subcommand) + { + syntax_error(Config.s_ChanServ, u, "BAN", CHAN_BAN_SYNTAX); + } + + void OnServHelp(User *u) + { + notice_lang(Config.s_ChanServ, u, CHAN_HELP_CMD_BAN); + } +}; + +class CSBan : public Module +{ + public: + CSBan(const std::string &modname, const std::string &creator) : Module(modname, creator) + { + this->SetAuthor("Anope"); + this->SetType(CORE); + this->AddCommand(ChanServ, new CommandCSBan("BAN")); + this->AddCommand(ChanServ, new CommandCSBan("KB")); + } +}; + +MODULE_INIT(CSBan) |