summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.gitignore1
-rw-r--r--data/commands.example.conf2
-rw-r--r--data/example.conf2
-rw-r--r--modules/core/os_kill.cpp72
4 files changed, 75 insertions, 2 deletions
diff --git a/.gitignore b/.gitignore
index b03785914..83ee1f848 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,4 +1,3 @@
config.cache
-include/version.h
include/sysconf.h
build/
diff --git a/data/commands.example.conf b/data/commands.example.conf
index ff487aa2d..03a5b01f6 100644
--- a/data/commands.example.conf
+++ b/data/commands.example.conf
@@ -291,6 +291,8 @@ module { name = "os_jupe" }
command { service = "OperServ"; name = "JUPE"; command = "operserv/jupe"; }
module { name = "os_kick" }
command { service = "OperServ"; name = "KICK"; command = "operserv/kick"; }
+module { name = "os_kill" }
+command { service = "OperServ"; name = "KILL"; command = "operserv/kill"; }
module { name = "os_login" }
command { service = "OperServ"; name = "LOGIN"; command = "operserv/login"; }
module { name = "os_mode" }
diff --git a/data/example.conf b/data/example.conf
index e44533461..5f2956681 100644
--- a/data/example.conf
+++ b/data/example.conf
@@ -1424,7 +1424,7 @@ log
* operserv/szline operserv/oper operserv/config operserv/umode
* operserv/modload operserv/jupe operserv/set operserv/noop
* operserv/quit operserv/update operserv/reload operserv/restart
- * operserv/shutdown operserv/svsnick operserv/oline
+ * operserv/shutdown operserv/svsnick operserv/oline operserv/kill
*
* Firstly, we define 'opertypes' which are named whatever we want ('Network Administrator', etc).
* These can contain commands for oper-only strings (see above) which grants access to that specific command,
diff --git a/modules/core/os_kill.cpp b/modules/core/os_kill.cpp
new file mode 100644
index 000000000..a3f9b658f
--- /dev/null
+++ b/modules/core/os_kill.cpp
@@ -0,0 +1,72 @@
+/* OperServ core functions
+ *
+ * (C) 2003-2011 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 CommandOSKill : public Command
+{
+ public:
+ CommandOSKill(Module *creator) : Command(creator, "operserv/kill", 1, 2, "operserv/kill")
+ {
+ this->SetDesc(_("Kill a user"));
+ this->SetSyntax(_("\037user\037 [\037reason\037]"));
+ }
+
+ void Execute(CommandSource &source, const std::vector<Anope::string> &params)
+ {
+ User *u = source.u;
+ const Anope::string &nick = params[0];
+ Anope::string reason = params.size() > 1 ? params[1] : "";
+
+ User *u2 = finduser(nick);
+ if (u2 == NULL)
+ source.Reply(NICK_X_NOT_IN_USE, nick.c_str());
+ else if (u2->IsProtected() || u2->server == Me)
+ source.Reply(ACCESS_DENIED);
+ else
+ {
+ if (reason.empty())
+ reason = "No reason specified";
+ if (Config->AddAkiller)
+ reason = "(" + u->nick + ") " + reason;
+ Log(LOG_ADMIN, u, this) << "on " << u2->nick << " for " << reason;
+ u2->Kill(Config->OperServ, reason);
+ }
+ }
+
+ bool OnHelp(CommandSource &source, const Anope::string &subcommand)
+ {
+ this->SendSyntax(source);
+ source.Reply(" ");
+ source.Reply(_("Allows you to kill a user from the network.\n"
+ "Parameters are the same as for the standard /KILL\n"
+ "command."));
+ return true;
+ }
+};
+
+class OSKill : public Module
+{
+ CommandOSKill commandoskill;
+
+ public:
+ OSKill(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, CORE),
+ commandoskill(this)
+ {
+ this->SetAuthor("Anope");
+
+ ModuleManager::RegisterService(&commandoskill);
+ }
+};
+
+MODULE_INIT(OSKill)