summaryrefslogtreecommitdiff
path: root/src/core/os_jupe.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/os_jupe.cpp')
-rw-r--r--src/core/os_jupe.cpp80
1 files changed, 80 insertions, 0 deletions
diff --git a/src/core/os_jupe.cpp b/src/core/os_jupe.cpp
new file mode 100644
index 000000000..7fedb968c
--- /dev/null
+++ b/src/core/os_jupe.cpp
@@ -0,0 +1,80 @@
+/* OperServ 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 CommandOSJupe : public Command
+{
+ public:
+ CommandOSJupe() : Command("JUPE", 1, 2, "operserv/jupe")
+ {
+ }
+
+ CommandReturn Execute(User *u, const std::vector<ci::string> &params)
+ {
+ const char *jserver = params[0].c_str();
+ const char *reason = params.size() > 1 ? params[1].c_str() : NULL;
+ Server *server = Server::Find(jserver);
+
+ if (!isValidHost(jserver, 3))
+ notice_lang(Config.s_OperServ, u, OPER_JUPE_HOST_ERROR);
+ else if (server && (server == Me || server == Me->GetUplink()))
+ notice_lang(Config.s_OperServ, u, OPER_JUPE_INVALID_SERVER);
+ else
+ {
+ char rbuf[256];
+ snprintf(rbuf, sizeof(rbuf), "Juped by %s%s%s", u->nick.c_str(), reason ? ": " : "", reason ? reason : "");
+ if (server)
+ ircdproto->SendSquit(jserver, rbuf);
+ Server *juped_server = new Server(Me, jserver, 0, rbuf, ircd->ts6 ? ts6_sid_retrieve() : "");
+ juped_server->SetFlag(SERVER_JUPED);
+ ircdproto->SendServer(juped_server);
+
+ if (Config.WallOSJupe)
+ ircdproto->SendGlobops(OperServ, "\2%s\2 used JUPE on \2%s\2", u->nick.c_str(), jserver);
+ }
+ return MOD_CONT;
+ }
+
+ bool OnHelp(User *u, const ci::string &subcommand)
+ {
+ notice_help(Config.s_OperServ, u, OPER_HELP_JUPE);
+ return true;
+ }
+
+ void OnSyntaxError(User *u, const ci::string &subcommand)
+ {
+ syntax_error(Config.s_OperServ, u, "JUPE", OPER_JUPE_SYNTAX);
+ }
+
+ void OnServHelp(User *u)
+ {
+ notice_lang(Config.s_OperServ, u, OPER_HELP_CMD_JUPE);
+ }
+};
+
+class OSJupe : public Module
+{
+ public:
+ OSJupe(const std::string &modname, const std::string &creator) : Module(modname, creator)
+ {
+ this->SetAuthor("Anope");
+ this->SetVersion(VERSION_STRING);
+ this->SetType(CORE);
+
+ this->AddCommand(OperServ, new CommandOSJupe());
+ }
+};
+
+MODULE_INIT(OSJupe)