1
0
mirror of https://github.com/anope/anope.git synced 2026-06-29 12:16:38 +02:00
Files
anope/modules/commands/os_login.cpp
T
Adam e66063e630 Rewrote the example configurations and split them
up into seperate files for each pseudo client.

Also reorganized how the modules are stored, and
made most of the old "extra" modules "core"
2011-08-05 05:35:31 -04:00

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> &params)
{
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)