summaryrefslogtreecommitdiff
path: root/modules/core/cs_ban.cpp
diff options
context:
space:
mode:
authorAdam <Adam@anope.org>2010-07-15 22:55:02 -0400
committerAdam <Adam@anope.org>2010-07-15 22:55:02 -0400
commita22f8d3b2de88b9bb6f80f0c2780846ae23ab389 (patch)
treea2fdf570868896a787df8a1169951b0028e68d6b /modules/core/cs_ban.cpp
parent43b1e43afb85639485e36d24da351dc0f121be6e (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.cpp111
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> &params)
+ {
+ 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)