diff options
Diffstat (limited to 'src/core/os_jupe.cpp')
-rw-r--r-- | src/core/os_jupe.cpp | 80 |
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> ¶ms) + { + 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) |