diff options
Diffstat (limited to 'src/modules')
-rw-r--r-- | src/modules/m_alias.cpp | 101 |
1 files changed, 54 insertions, 47 deletions
diff --git a/src/modules/m_alias.cpp b/src/modules/m_alias.cpp index 096bdb588..25c6960cc 100644 --- a/src/modules/m_alias.cpp +++ b/src/modules/m_alias.cpp @@ -124,7 +124,6 @@ class ModuleAlias : public Module virtual int OnPreCommand(std::string &command, std::vector<std::string> ¶meters, User *user, bool validated, const std::string &original_line) { - User *u = NULL; std::multimap<std::string, Alias>::iterator i; /* If theyre not registered yet, we dont want @@ -152,66 +151,74 @@ class ModuleAlias : public Module while (i != Aliases.end()) { - /* Does it match the pattern? */ - if (!i->second.format.empty()) - { - if (i->second.case_sensitive) - { - if (InspIRCd::Match(compare, i->second.format, case_sensitive_map)) - continue; - } - else - { - if (InspIRCd::Match(compare, i->second.format)) - continue; - } - } + DoAlias(user, &(i->second), compare, safe); - if ((i->second.operonly) && (!IS_OPER(user))) - return 0; + i++; + } + + // If aliases have been processed, aliases took it. + return 1; + } - if (!i->second.requires.empty()) + void DoAlias(User *user, Alias *a, const std::string compare, const std::string safe) + { + User *u = NULL; + /* Does it match the pattern? */ + if (!a->format.empty()) + { + if (a->case_sensitive) { - u = ServerInstance->FindNick(i->second.requires); - if (!u) - { - user->WriteNumeric(401, ""+std::string(user->nick)+" "+i->second.requires+" :is currently unavailable. Please try again later."); - return 1; - } + if (InspIRCd::Match(compare, a->format, case_sensitive_map)) + return; } - if ((u != NULL) && (!i->second.requires.empty()) && (i->second.uline)) + else { - if (!ServerInstance->ULine(u->server)) - { - ServerInstance->SNO->WriteToSnoMask('A', "NOTICE -- Service "+i->second.requires+" required by alias "+std::string(i->second.text.c_str())+" is not on a u-lined server, possibly underhanded antics detected!"); - user->WriteNumeric(401, ""+std::string(user->nick)+" "+i->second.requires+" :is an imposter! Please inform an IRC operator as soon as possible."); - return 1; - } + if (InspIRCd::Match(compare, a->format)) + return; } + } - /* Now, search and replace in a copy of the original_line, replacing $1 through $9 and $1- etc */ - - std::string::size_type crlf = i->second.replace_with.find('\n'); + if ((a->operonly) && (!IS_OPER(user))) + return; - if (crlf == std::string::npos) + if (!a->requires.empty()) + { + u = ServerInstance->FindNick(a->requires); + if (!u) { - DoCommand(i->second.replace_with, user, safe); - return 1; + user->WriteNumeric(401, ""+std::string(user->nick)+" "+a->requires+" :is currently unavailable. Please try again later."); + return; } - else + } + if ((u != NULL) && (!a->requires.empty()) && (a->uline)) + { + if (!ServerInstance->ULine(u->server)) { - irc::sepstream commands(i->second.replace_with, '\n'); - std::string scommand; - while (commands.GetToken(scommand)) - { - DoCommand(scommand, user, safe); - } - return 1; + ServerInstance->SNO->WriteToSnoMask('A', "NOTICE -- Service "+a->requires+" required by alias "+std::string(a->text.c_str())+" is not on a u-lined server, possibly underhanded antics detected!"); + user->WriteNumeric(401, ""+std::string(user->nick)+" "+a->requires+" :is an imposter! Please inform an IRC operator as soon as possible."); + return; } + } - i++; + /* Now, search and replace in a copy of the original_line, replacing $1 through $9 and $1- etc */ + + std::string::size_type crlf = a->replace_with.find('\n'); + + if (crlf == std::string::npos) + { + DoCommand(a->replace_with, user, safe); + return; + } + else + { + irc::sepstream commands(a->replace_with, '\n'); + std::string scommand; + while (commands.GetToken(scommand)) + { + DoCommand(scommand, user, safe); + } + return; } - return 0; } void DoCommand(std::string newline, User* user, const std::string &original_line) |