diff options
Diffstat (limited to 'modules/operserv/shutdown.cpp')
-rw-r--r-- | modules/operserv/shutdown.cpp | 109 |
1 files changed, 109 insertions, 0 deletions
diff --git a/modules/operserv/shutdown.cpp b/modules/operserv/shutdown.cpp new file mode 100644 index 000000000..c0adc182e --- /dev/null +++ b/modules/operserv/shutdown.cpp @@ -0,0 +1,109 @@ +/* + * Anope IRC Services + * + * Copyright (C) 2003-2016 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 CommandOSQuit : public Command +{ + public: + CommandOSQuit(Module *creator) : Command(creator, "operserv/quit", 0, 0) + { + this->SetDesc(_("Terminate Services without saving")); + } + + void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) override + { + Log(LOG_ADMIN, source, this); + Anope::QuitReason = source.command + " command received from " + source.GetNick(); + Anope::Quitting = true; + return; + } + + bool OnHelp(CommandSource &source, const Anope::string &subcommand) override + { + source.Reply(_("Causes Services to do an immediate shutdown; databases may \002not\002 saved." + " If you are using a real time database such as SQL or Redis, this command is not useful." + " This command should not be used unless damage to the in-memory copies of the databases is feared and they should not be saved.")); + return true; + } +}; + +class CommandOSRestart : public Command +{ + public: + CommandOSRestart(Module *creator) : Command(creator, "operserv/restart", 0, 0) + { + this->SetDesc(_("Save databases and restart Services")); + } + + void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) override + { + Log(LOG_ADMIN, source, this); + Anope::QuitReason = source.command + " command received from " + source.GetNick(); + Anope::Quitting = Anope::Restarting = true; + Anope::SaveDatabases(); + return; + } + + bool OnHelp(CommandSource &source, const Anope::string &subcommand) override + { + source.Reply(_("Causes Services to restart.")); + return true; + } +}; + +class CommandOSShutdown : public Command +{ + public: + CommandOSShutdown(Module *creator) : Command(creator, "operserv/shutdown", 0, 0) + { + this->SetDesc(_("Terminate services with save")); + } + + void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) override + { + Log(LOG_ADMIN, source, this); + Anope::QuitReason = source.command + " command received from " + source.GetNick(); + Anope::Quitting = true; + Anope::SaveDatabases(); + return; + } + + bool OnHelp(CommandSource &source, const Anope::string &subcommand) override + { + source.Reply(_("Causes Services to shut down")); + return true; + } +}; + +class OSShutdown : public Module +{ + CommandOSQuit commandosquit; + CommandOSRestart commandosrestart; + CommandOSShutdown commandosshutdown; + + public: + OSShutdown(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, VENDOR), + commandosquit(this), commandosrestart(this), commandosshutdown(this) + { + + } +}; + +MODULE_INIT(OSShutdown) |