diff options
Diffstat (limited to 'modules/operserv/shutdown.cpp')
-rw-r--r-- | modules/operserv/shutdown.cpp | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/modules/operserv/shutdown.cpp b/modules/operserv/shutdown.cpp new file mode 100644 index 000000000..0e2035d86 --- /dev/null +++ b/modules/operserv/shutdown.cpp @@ -0,0 +1,79 @@ +/* + * Anope IRC Services + * + * Copyright (C) 2003-2017 Anope Team <team@anope.org> + * + * This file is part of Anope. Anope is free software; you can + * redistribute it and/or modify it under the terms of the GNU + * General Public License as published by the Free Software + * Foundation, version 2. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, see see <http://www.gnu.org/licenses/>. + */ + +#include "module.h" + +class CommandOSRestart : public Command +{ + public: + CommandOSRestart(Module *creator) : Command(creator, "operserv/restart", 0, 0) + { + this->SetDesc(_("Restart Anope")); + } + + void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) override + { + logger.Admin(source, _("{source} used {command}")); + Anope::QuitReason = source.GetCommand() + " command received from " + source.GetNick(); + Anope::Quitting = Anope::Restarting = true; + } + + bool OnHelp(CommandSource &source, const Anope::string &subcommand) override + { + source.Reply(_("Causes Anope to restart.")); + return true; + } +}; + +class CommandOSShutdown : public Command +{ + public: + CommandOSShutdown(Module *creator) : Command(creator, "operserv/shutdown", 0, 0) + { + this->SetDesc(_("Shutdown Anope")); + } + + void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) override + { + logger.Admin(source, _("{source} used {command}")); + Anope::QuitReason = source.GetCommand() + " command received from " + source.GetNick(); + Anope::Quitting = true; + } + + bool OnHelp(CommandSource &source, const Anope::string &subcommand) override + { + source.Reply(_("Causes Anope to shut down")); + return true; + } +}; + +class OSShutdown : public Module +{ + CommandOSRestart commandosrestart; + CommandOSShutdown commandosshutdown; + + public: + OSShutdown(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, VENDOR) + , commandosrestart(this) + , commandosshutdown(this) + { + } +}; + +MODULE_INIT(OSShutdown) |