Fix rcon command
This commit is contained in:
parent
3748ed3efc
commit
3ab54b1b68
@ -9,6 +9,42 @@ namespace Components
|
|||||||
|
|
||||||
RCon::RCon()
|
RCon::RCon()
|
||||||
{
|
{
|
||||||
|
Command::Add("rcon", [] (Command::Params params)
|
||||||
|
{
|
||||||
|
if (params.Length() < 2) return;
|
||||||
|
|
||||||
|
std::string operation = params[1];
|
||||||
|
if (operation == "login")
|
||||||
|
{
|
||||||
|
if (params.Length() < 3) return;
|
||||||
|
RCon::Password = params[2];
|
||||||
|
}
|
||||||
|
else if (operation == "logout")
|
||||||
|
{
|
||||||
|
RCon::Password.clear();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!RCon::Password.empty() && *reinterpret_cast<int*>(0xB2C540) >= 5) // Get our state
|
||||||
|
{
|
||||||
|
Network::Address target(reinterpret_cast<Game::netadr_t*>(0xA5EA44));
|
||||||
|
|
||||||
|
if (target.IsValid())
|
||||||
|
{
|
||||||
|
Network::SendCommand(target, "rcon", RCon::Password + " " + params.Join(1));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Logger::Print("You are connected to an invalid server\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Logger::Print("You need to be logged in and connected to a server!\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// TODO: Maybe execute that for clients as well, when we use triangular natting.
|
// TODO: Maybe execute that for clients as well, when we use triangular natting.
|
||||||
if (!Dedicated::IsDedicated()) return;
|
if (!Dedicated::IsDedicated()) return;
|
||||||
|
|
||||||
@ -125,42 +161,6 @@ namespace Components
|
|||||||
RCon::BackdoorContainer.output.clear();
|
RCon::BackdoorContainer.output.clear();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
Command::Add("rcon", [] (Command::Params params)
|
|
||||||
{
|
|
||||||
if (params.Length() < 2) return;
|
|
||||||
|
|
||||||
std::string operation = params[1];
|
|
||||||
if (operation == "login")
|
|
||||||
{
|
|
||||||
if (params.Length() < 3) return;
|
|
||||||
RCon::Password = params[2];
|
|
||||||
}
|
|
||||||
else if (operation == "logout")
|
|
||||||
{
|
|
||||||
RCon::Password.clear();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (!RCon::Password.empty() && *reinterpret_cast<int*>(0xB2C540) >= 5) // Get our state
|
|
||||||
{
|
|
||||||
Network::Address target(reinterpret_cast<Game::netadr_t*>(0xA5EA44));
|
|
||||||
|
|
||||||
if (target.IsValid())
|
|
||||||
{
|
|
||||||
Network::SendCommand(target, "rcon", RCon::Password + " " + params.Join(1));
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Logger::Print("You are connected to an invalid server\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Logger::Print("You need to be logged in and connected to a server!\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
RCon::~RCon()
|
RCon::~RCon()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user