summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/configreader.cpp2
-rw-r--r--src/whois.cpp13
2 files changed, 11 insertions, 4 deletions
diff --git a/src/configreader.cpp b/src/configreader.cpp
index d6b479874..6435d43bd 100644
--- a/src/configreader.cpp
+++ b/src/configreader.cpp
@@ -591,7 +591,7 @@ void ServerConfig::Fill()
if (v == "splitmsg")
OperSpyWhois = SPYWHOIS_SPLITMSG;
else if (v == "on" || v == "yes")
- OperSpyWhois = SPYWHOIS_NEWLINE;
+ OperSpyWhois = SPYWHOIS_SINGLEMSG;
else
OperSpyWhois = SPYWHOIS_NONE;
diff --git a/src/whois.cpp b/src/whois.cpp
index 4aa5e4726..27b07c944 100644
--- a/src/whois.cpp
+++ b/src/whois.cpp
@@ -22,14 +22,21 @@ void InspIRCd::DoWhois(User* user, User* dest,unsigned long signon, unsigned lon
}
std::string cl = dest->ChannelList(user, false);
+ const ServerConfig::OperSpyWhoisState state = user->HasPrivPermission("users/auspex") ? ServerInstance->Config->OperSpyWhois : ServerConfig::SPYWHOIS_NONE;
+
+ if (state == ServerConfig::SPYWHOIS_SINGLEMSG)
+ cl.append(dest->ChannelList(user, true));
user->SplitChanList(dest,cl);
- if (user->HasPrivPermission("users/auspex") && ServerInstance->Config->OperSpyWhois != ServerConfig::SPYWHOIS_NONE)
+
+ if (state == ServerConfig::SPYWHOIS_SPLITMSG)
{
std::string scl = dest->ChannelList(user, true);
- if (scl.length() && ServerInstance->Config->OperSpyWhois == ServerConfig::SPYWHOIS_SPLITMSG)
+ if (scl.length())
+ {
SendWhoisLine(user, dest, 336, "%s %s :is on private/secret channels:",user->nick.c_str(), dest->nick.c_str());
- user->SplitChanList(dest,scl);
+ user->SplitChanList(dest,scl);
+ }
}
if (user != dest && !this->Config->HideWhoisServer.empty() && !user->HasPrivPermission("servers/auspex"))
{