diff options
Diffstat (limited to 'modules/commands/ns_logout.cpp')
-rw-r--r-- | modules/commands/ns_logout.cpp | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/modules/commands/ns_logout.cpp b/modules/commands/ns_logout.cpp new file mode 100644 index 000000000..476330a11 --- /dev/null +++ b/modules/commands/ns_logout.cpp @@ -0,0 +1,97 @@ +/* NickServ 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" +#include "nickserv.h" + +class CommandNSLogout : public Command +{ + public: + CommandNSLogout(Module *creator) : Command(creator, "nickserv/logout", 0, 2) + { + this->SetDesc(_("Reverses the effect of the IDENTIFY command")); + this->SetSyntax(_("[\037nickname\037 [REVALIDATE]]")); + } + + void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) + { + User *u = source.u; + + const Anope::string &nick = !params.empty() ? params[0] : ""; + const Anope::string ¶m = params.size() > 1 ? params[1] : ""; + + User *u2; + if (!u->IsServicesOper() && !nick.empty()) + this->OnSyntaxError(source, ""); + else if (!(u2 = (!nick.empty() ? finduser(nick) : u))) + source.Reply(NICK_X_NOT_IN_USE, nick.c_str()); + else if (!nick.empty() && !u2->IsServicesOper()) + source.Reply(_("You can't logout %s because they are a Services Operator."), nick.c_str()); + else + { + if (!nick.empty() && !param.empty() && param.equals_ci("REVALIDATE") && nickserv) + nickserv->Validate(u2); + + u2->isSuperAdmin = 0; /* Dont let people logout and remain a SuperAdmin */ + Log(LOG_COMMAND, u, this) << "to logout " << u2->nick; + + /* Remove founder status from this user in all channels */ + if (!nick.empty()) + source.Reply(_("Nick %s has been logged out."), nick.c_str()); + else + source.Reply(_("Your nick has been logged out.")); + + ircdproto->SendAccountLogout(u2, u2->Account()); + u2->RemoveMode(source.owner, UMODE_REGISTERED); + ircdproto->SendUnregisteredNick(u2); + + u2->Logout(); + + /* Send out an event */ + FOREACH_MOD(I_OnNickLogout, OnNickLogout(u2)); + } + return; + } + + bool OnHelp(CommandSource &source, const Anope::string &subcommand) + { + this->SendSyntax(source); + source.Reply(" "); + source.Reply(_("Without a parameter, reverses the effect of the \002IDENTIFY\002 \n" + "command, i.e. make you not recognized as the real owner of the nick\n" + "anymore. Note, however, that you won't be asked to reidentify\n" + "yourself.\n" + " \n" + "With a parameter, does the same for the given nick. If you \n" + "specify REVALIDATE as well, Services will ask the given nick\n" + "to re-identify. This use limited to \002Services Operators\002.")); + + return true; + } +}; + +class NSLogout : public Module +{ + CommandNSLogout commandnslogout; + + public: + NSLogout(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, CORE), + commandnslogout(this) + { + this->SetAuthor("Anope"); + + ModuleManager::RegisterService(&commandnslogout); + } +}; + +MODULE_INIT(NSLogout) |