SetFd(FD_FAKEUSER_NUMBER);
}
- virtual const std::string GetFullHost() { return server; }
- virtual const std::string GetFullRealHost() { return server; }
+ virtual const std::string GetFullHost() { return nick; }
+ virtual const std::string GetFullRealHost() { return nick; }
+ void SetFakeServer(std::string name);
};
#endif
/* set up fake client again this time with the correct uid */
this->FakeClient = new FakeUser(this, "!");
+ this->FakeClient->SetFakeServer(Config->ServerName);
// Get XLine to do it's thing.
this->XLines->CheckELines();
modelist.push_back(params[idx]);
}
- this->ServerInstance->SendMode(modelist, this->ServerInstance->FakeClient);
+ this->ServerInstance->SendMode(modelist, Utils->ServerUser);
}
/* Now, process every 'modes,nick' pair */
while (modestack.GetStackedLine(stackresult))
{
mode_junk.insert(mode_junk.end(), stackresult.begin(), stackresult.end());
- ServerInstance->SendMode(mode_junk, ServerInstance->FakeClient);
+ ServerInstance->SendMode(mode_junk, Utils->ServerUser);
mode_junk.erase(mode_junk.begin() + 1, mode_junk.end());
}
}
while (stack.GetStackedLine(stackresult))
{
mode_junk.insert(mode_junk.end(), stackresult.begin(), stackresult.end());
- ServerInstance->SendMode(mode_junk, ServerInstance->FakeClient);
+ ServerInstance->SendMode(mode_junk, Utils->ServerUser);
mode_junk.erase(mode_junk.begin() + 1, mode_junk.end());
}
}
return true;
}
- bool smode = false;
std::string sourceserv;
/* Are we dealing with an FMODE from a user, or from a server? */
else
{
/* FMODE from a server, use a fake user to receive mode feedback */
- who = this->ServerInstance->FakeClient;
- smode = true; /* Setting this flag tells us it is a server mode*/
+ who = Utils->ServerUser;
sourceserv = source; /* Set sourceserv to the actual source string */
}
std::vector<std::string> modelist;
*/
if (TS <= ourTS)
{
- if (smode)
- {
- this->ServerInstance->SendMode(modelist, who);
- }
- else
- {
- this->ServerInstance->CallCommandHandler("MODE", modelist, who);
- }
+ ServerInstance->Modes->Process(modelist, who, (who == Utils->ServerUser));
+
/* HOT POTATO! PASS IT ON! */
Utils->DoOneToAllButSender(source,"FMODE",params,sourceserv);
}
TreeServer *ServerSource = Utils->FindServer(prefix);
if (ServerSource)
{
- // ServerSource->GetName().c_str() may become invalid before it is used
- Utils->ServerUser->nick = ServerSource->GetName().c_str();
- Utils->ServerUser->server = Utils->ServerUser->nick.c_str();
+ Utils->ServerUser->SetFakeServer(ServerSource->GetName());
Utils->ServerUser->uuid = ServerSource->GetID();
}
this->Penalty -= decrease;
}
+void FakeUser::SetFakeServer(std::string name)
+{
+ this->nick = name;
+ this->server = nick.c_str();
+}
+
VisData::VisData()
{
}