diff options
Diffstat (limited to 'modules/commands/ns_getpass.cpp')
-rw-r--r-- | modules/commands/ns_getpass.cpp | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/modules/commands/ns_getpass.cpp b/modules/commands/ns_getpass.cpp new file mode 100644 index 000000000..9ebea5263 --- /dev/null +++ b/modules/commands/ns_getpass.cpp @@ -0,0 +1,79 @@ +/* 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" + +class CommandNSGetPass : public Command +{ + public: + CommandNSGetPass(Module *creator) : Command(creator, "nickserv/getpass", 1, 1) + { + this->SetDesc(_("Retrieve the password for a nickname")); + this->SetSyntax(_("\037nickname\037")); + } + + void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms) + { + User *u = source.u; + const Anope::string &nick = params[0]; + Anope::string tmp_pass; + NickAlias *na; + + if (!(na = findnick(nick))) + source.Reply(NICK_X_NOT_REGISTERED, nick.c_str()); + else if (Config->NSSecureAdmins && na->nc->IsServicesOper()) + source.Reply(ACCESS_DENIED); + else + { + if (enc_decrypt(na->nc->pass, tmp_pass) == 1) + { + Log(LOG_ADMIN, u, this) << "for " << nick; + source.Reply(_("Password for %s is \002%s\002."), nick.c_str(), tmp_pass.c_str()); + } + else + source.Reply(_("GETPASS command unavailable because encryption is in use.")); + } + return; + } + + bool OnHelp(CommandSource &source, const Anope::string &subcommand) + { + this->SendSyntax(source); + source.Reply(" "); + source.Reply(_("Returns the password for the given nickname. \002Note\002 that\n" + "whenever this command is used, a message including the\n" + "person who issued the command and the nickname it was used\n" + "on will be logged and sent out as a WALLOPS/GLOBOPS.")); + return true; + } +}; + +class NSGetPass : public Module +{ + CommandNSGetPass commandnsgetpass; + + public: + NSGetPass(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, CORE), + commandnsgetpass(this) + { + this->SetAuthor("Anope"); + + Anope::string tmp_pass = "plain:tmp"; + if (enc_decrypt(tmp_pass, tmp_pass) == -1) + throw ModuleException("Incompatible with the encryption module being used"); + + ModuleManager::RegisterService(&commandnsgetpass); + } +}; + +MODULE_INIT(NSGetPass) |