/* 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 ¶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::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)