AChannel_M(Module* Creator) : SimpleChannelModeHandler(Creator, "regmoderated", 'M') { }
};
-static bool ReadCGIIRCExt(const char* extname, User* user, const std::string*& out)
-{
- ExtensionItem* wiext = ServerInstance->Extensions.GetItem(extname);
- if (!wiext)
- return false;
-
- if (wiext->creator->ModuleSourceFile != "m_cgiirc.so")
- return false;
-
- StringExtItem* stringext = static_cast<StringExtItem*>(wiext);
- std::string* addr = stringext->get(user);
- if (!addr)
- return false;
-
- out = addr;
- return true;
-}
-
class AccountExtItemImpl : public AccountExtItem
{
public:
// Logged in
if (IS_LOCAL(user))
{
- const std::string* host = &user->dhost;
- if (user->registered != REG_ALL)
- {
- if (!ReadCGIIRCExt("cgiirc_webirc_hostname", user, host))
- {
- ReadCGIIRCExt("cgiirc_webirc_ip", user, host);
- }
- }
-
- user->WriteNumeric(900, "%s!%s@%s %s :You are now logged in as %s",
- user->nick.c_str(), user->ident.c_str(), host->c_str(), value.c_str(), value.c_str());
+ user->WriteNumeric(900, "%s %s :You are now logged in as %s",
+ user->GetFullHost().c_str(), value.c_str(), value.c_str());
}
AccountEvent(creator, user, value).Send();
public:
ModuleServicesAccount() : m1(this), m2(this), m3(this), m4(this), m5(this),
accountname(this)
+ , checking_ban(false)
{
}
{
/* On nickchange, if they have +r, remove it */
if (user->IsModeSet(m5) && assign(user->nick) != oldnick)
- {
- std::vector<std::string> modechange;
- modechange.push_back(user->nick);
- modechange.push_back("-r");
- ServerInstance->Modes->Process(modechange, ServerInstance->FakeClient, ModeParser::MODE_LOCALONLY);
- }
+ m5.RemoveMode(user);
}
ModResult OnUserPreMessage(User* user, void* dest, int target_type, std::string& text, char status, CUList& exempt_list, MessageType msgtype) CXX11_OVERRIDE