mirror of
https://github.com/anope/anope.git
synced 2026-06-29 12:16:38 +02:00
e66063e630
up into seperate files for each pseudo client. Also reorganized how the modules are stored, and made most of the old "extra" modules "core"
98 lines
2.4 KiB
C++
98 lines
2.4 KiB
C++
/* OperServ 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 CommandOSLogin : public Command
|
|
{
|
|
public:
|
|
CommandOSLogin(Module *creator) : Command(creator, "operserv/login", 1, 1)
|
|
{
|
|
this->SetDesc(Anope::printf(_("Login to %s"), Config->OperServ.c_str()));
|
|
this->SetSyntax(_("\037password\037"));
|
|
}
|
|
|
|
void Execute(CommandSource &source, const std::vector<Anope::string> ¶ms)
|
|
{
|
|
const Anope::string &password = params[0];
|
|
|
|
Oper *o = source.u->Account()->o;
|
|
if (o == NULL)
|
|
source.Reply(_("No oper block for your nick."));
|
|
else if (o->password.empty())
|
|
source.Reply(_("Your oper block doesn't require logging in."));
|
|
else if (source.u->GetExt("os_login_password_correct"))
|
|
source.Reply(_("You are already identified."));
|
|
else if (o->password != password)
|
|
{
|
|
source.Reply(PASSWORD_INCORRECT);
|
|
bad_password(source.u);
|
|
}
|
|
else
|
|
{
|
|
Log(LOG_ADMIN, source.u, this) << "and successfully identified to " << source.owner->nick;
|
|
source.u->Extend("os_login_password_correct");
|
|
source.Reply(_("Password accepted."));
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
bool OnHelp(CommandSource &source, const Anope::string &subcommand)
|
|
{
|
|
this->SendSyntax(source);
|
|
source.Reply(" ");
|
|
source.Reply(_("Logs you in to %s so you gain Services Operator privileges.\n"
|
|
"This command may be unnecessary if your oper block is\n"
|
|
"configured without a password."), source.owner->nick.c_str());
|
|
return true;
|
|
}
|
|
};
|
|
|
|
class OSLogin : public Module
|
|
{
|
|
CommandOSLogin commandoslogin;
|
|
|
|
public:
|
|
OSLogin(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, CORE),
|
|
commandoslogin(this)
|
|
{
|
|
this->SetAuthor("Anope");
|
|
|
|
ModuleManager::RegisterService(&commandoslogin);
|
|
|
|
ModuleManager::Attach(I_IsServicesOper, this);
|
|
}
|
|
|
|
~OSLogin()
|
|
{
|
|
for (Anope::insensitive_map<User *>::const_iterator it = UserListByNick.begin(); it != UserListByNick.end(); ++it)
|
|
it->second->Shrink("os_login_password_correct");
|
|
}
|
|
|
|
EventReturn IsServicesOper(User *u)
|
|
{
|
|
if (!u->Account()->o->password.empty())
|
|
{
|
|
if (u->GetExt("os_login_password_correct"))
|
|
return EVENT_ALLOW;
|
|
return EVENT_STOP;
|
|
}
|
|
|
|
return EVENT_CONTINUE;
|
|
}
|
|
};
|
|
|
|
MODULE_INIT(OSLogin)
|