1
0
Fork 1
mirror of https://github.com/TES3MP/openmw-tes3mp.git synced 2025-01-19 23:23:52 +00:00

[Master] Add isServerValid lambda. Add "OnServerAnnounce" callback

This commit is contained in:
Koncord 2017-09-12 21:29:42 +08:00
parent f99dafbf51
commit dc18916f46

View file

@ -47,6 +47,11 @@ MasterServer::MasterServer(const std::string &luaScript)
state.set_function("BanAddress", [this](const string &address) {
this->ban(address);
});
state.new_usertype<MasterServer::SServer>("Server",
"name", sol::property(&MasterServer::SServer::GetName),
"gamemode", sol::property(&MasterServer::SServer::GetGameMode),
"version", sol::property(&MasterServer::SServer::GetVersion)
);
state.set_function("UnbanAddress", [this](const string &address) {
this->unban(address);
@ -173,6 +178,24 @@ void MasterServer::Thread()
pendingACKs[packet->guid] = steady_clock::now();
};
auto isServerValid = [&](const SServer &sserver) {
bool ret = false;
auto addr = packet->systemAddress.ToString(false);
if (find(banned.begin(), banned.end(), addr) != banned.end()) // check if address is banned
return true;
luaStuff([&ret, &packet, &sserver, &addr](sol::state &state) {
sol::protected_function func = state["OnServerAnnounce"];
sol::protected_function_result result = func.call(addr, sserver);
if (result.valid())
ret = result.get<bool>();
else
cerr << "Error: " << result.get<string>() << endl;
});
return ret;
};
if (iter != servers.end())
{
if (pma.GetFunc() == PacketMasterAnnounce::FUNCTION_DELETE)
@ -185,8 +208,17 @@ void MasterServer::Thread()
else if (pma.GetFunc() == PacketMasterAnnounce::FUNCTION_ANNOUNCE)
{
cout << "Updated";
iter->second = server;
keepAliveFunc();
if (isServerValid(server))
{
iter->second = server;
keepAliveFunc();
}
else
{
servers.erase(iter);
pendingACKs[packet->guid] = steady_clock::now();
}
}
else
{
@ -197,8 +229,11 @@ void MasterServer::Thread()
else if (pma.GetFunc() == PacketMasterAnnounce::FUNCTION_ANNOUNCE)
{
cout << "Added";
iter = servers.insert({packet->systemAddress, server}).first;
keepAliveFunc();
if (isServerValid(server))
{
iter = servers.insert({packet->systemAddress, server}).first;
keepAliveFunc();
}
}
else
{