mirror of
https://github.com/anope/anope.git
synced 2026-06-25 19:56:39 +02:00
86 lines
2.3 KiB
C++
86 lines
2.3 KiB
C++
/* 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() : Command("GETPASS", 1, 1, "nickserv/getpass")
|
|
{
|
|
this->SetDesc(_("Retrieve the password for a nickname"));
|
|
}
|
|
|
|
CommandReturn 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 (na->HasFlag(NS_FORBIDDEN))
|
|
source.Reply(_(NICK_X_FORBIDDEN), na->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 MOD_CONT;
|
|
}
|
|
|
|
bool OnHelp(CommandSource &source, const Anope::string &subcommand)
|
|
{
|
|
source.Reply(_("Syntax: \002GETPASS \037nickname\037\002\n"
|
|
" \n"
|
|
"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;
|
|
}
|
|
|
|
void OnSyntaxError(CommandSource &source, const Anope::string &subcommand)
|
|
{
|
|
SyntaxError(source, "GETPASS", _("GETPASS \037nickname\037"));
|
|
}
|
|
};
|
|
|
|
class NSGetPass : public Module
|
|
{
|
|
CommandNSGetPass commandnsgetpass;
|
|
|
|
public:
|
|
NSGetPass(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator)
|
|
{
|
|
Anope::string tmp_pass = "plain:tmp";
|
|
if (enc_decrypt(tmp_pass, tmp_pass) == -1)
|
|
throw ModuleException("Incompatible with the encryption module being used");
|
|
|
|
this->SetAuthor("Anope");
|
|
this->SetType(CORE);
|
|
|
|
this->AddCommand(NickServ, &commandnsgetpass);
|
|
}
|
|
};
|
|
|
|
MODULE_INIT(NSGetPass)
|