mirror of
https://github.com/Mauler125/r5sdk.git
synced 2025-02-09 19:15:03 +01:00
Move unban logic to CBanSystem and expose to Squirrel
New unban function in SERVER context 'UnbanPlayer(string criteria)'.
This commit is contained in:
parent
9c9843a0fc
commit
a68f55dac0
@ -308,7 +308,7 @@ void CBanSystem::KickPlayerByName(const string& svPlayerName)
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: kicks a player by given handle or id
|
||||
// Input : svHandle -
|
||||
// Input : &svHandle -
|
||||
//-----------------------------------------------------------------------------
|
||||
void CBanSystem::KickPlayerById(const string& svHandle)
|
||||
{
|
||||
@ -399,7 +399,7 @@ void CBanSystem::BanPlayerByName(const string& svPlayerName)
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: bans a player by given handle or id
|
||||
// Input : svHandle -
|
||||
// Input : &svHandle -
|
||||
//-----------------------------------------------------------------------------
|
||||
void CBanSystem::BanPlayerById(const string& svHandle)
|
||||
{
|
||||
@ -466,5 +466,35 @@ void CBanSystem::BanPlayerById(const string& svHandle)
|
||||
}
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: unbans a player by given nucleus id or ip address
|
||||
// Input : &svCriteria -
|
||||
//-----------------------------------------------------------------------------
|
||||
void CBanSystem::UnbanPlayer(const string& svCriteria)
|
||||
{
|
||||
try
|
||||
{
|
||||
if (StringIsDigit(svCriteria)) // Check if we have an ip address or nucleus id.
|
||||
{
|
||||
if (DeleteEntry("<<invalid>>", std::stoll(svCriteria))) // Delete ban entry.
|
||||
{
|
||||
Save(); // Save modified vector to file.
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (DeleteEntry(svCriteria, 0)) // Delete ban entry.
|
||||
{
|
||||
Save(); // Save modified vector to file.
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (const std::exception& e)
|
||||
{
|
||||
Error(eDLL_T::SERVER, NO_ERROR, "%s - %s", __FUNCTION__, e.what());
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
CBanSystem* g_pBanSystem = new CBanSystem();
|
||||
|
@ -24,6 +24,8 @@ public:
|
||||
void BanPlayerByName(const string& svPlayerName);
|
||||
void BanPlayerById(const string& svHandle);
|
||||
|
||||
void UnbanPlayer(const string& svCriteria);
|
||||
|
||||
private:
|
||||
vector<std::pair<string, uint64_t>> m_vRefuseList = {};
|
||||
vector<std::pair<string, uint64_t>> m_vBanList = {};
|
||||
|
@ -128,8 +128,8 @@ namespace VSquirrel
|
||||
//-----------------------------------------------------------------------------
|
||||
SQRESULT KickPlayerByName(HSQUIRRELVM v)
|
||||
{
|
||||
SQChar* szPlayer = sq_getstring(v, 1);
|
||||
g_pBanSystem->KickPlayerByName(szPlayer);
|
||||
SQChar* szName = sq_getstring(v, 1);
|
||||
g_pBanSystem->KickPlayerByName(szName);
|
||||
|
||||
return SQ_OK;
|
||||
}
|
||||
@ -139,8 +139,8 @@ namespace VSquirrel
|
||||
//-----------------------------------------------------------------------------
|
||||
SQRESULT KickPlayerById(HSQUIRRELVM v)
|
||||
{
|
||||
SQChar* szPlayer = sq_getstring(v, 1);
|
||||
g_pBanSystem->KickPlayerById(szPlayer);
|
||||
SQChar* szHandle = sq_getstring(v, 1);
|
||||
g_pBanSystem->KickPlayerById(szHandle);
|
||||
|
||||
return SQ_OK;
|
||||
}
|
||||
@ -150,8 +150,8 @@ namespace VSquirrel
|
||||
//-----------------------------------------------------------------------------
|
||||
SQRESULT BanPlayerByName(HSQUIRRELVM v)
|
||||
{
|
||||
SQChar* szPlayer = sq_getstring(v, 1);
|
||||
g_pBanSystem->BanPlayerByName(szPlayer);
|
||||
SQChar* szName = sq_getstring(v, 1);
|
||||
g_pBanSystem->BanPlayerByName(szName);
|
||||
|
||||
return SQ_OK;
|
||||
}
|
||||
@ -161,8 +161,19 @@ namespace VSquirrel
|
||||
//-----------------------------------------------------------------------------
|
||||
SQRESULT BanPlayerById(HSQUIRRELVM v)
|
||||
{
|
||||
SQChar* szPlayer = sq_getstring(v, 1);
|
||||
g_pBanSystem->BanPlayerById(szPlayer);
|
||||
SQChar* szHandle = sq_getstring(v, 1);
|
||||
g_pBanSystem->BanPlayerById(szHandle);
|
||||
|
||||
return SQ_OK;
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
// Purpose: unbans a player by given nucleus id or ip address
|
||||
//-----------------------------------------------------------------------------
|
||||
SQRESULT UnbanPlayer(HSQUIRRELVM v)
|
||||
{
|
||||
SQChar* szCriteria = sq_getstring(v, 1);
|
||||
g_pBanSystem->UnbanPlayer(szCriteria);
|
||||
|
||||
return SQ_OK;
|
||||
}
|
||||
|
@ -33,6 +33,7 @@ namespace VSquirrel
|
||||
SQRESULT KickPlayerById(HSQUIRRELVM v);
|
||||
SQRESULT BanPlayerByName(HSQUIRRELVM v);
|
||||
SQRESULT BanPlayerById(HSQUIRRELVM v);
|
||||
SQRESULT UnbanPlayer(HSQUIRRELVM v);
|
||||
}
|
||||
#endif // !CLIENT_DLL
|
||||
#ifndef DEDICATED
|
||||
|
@ -60,6 +60,8 @@ void Script_RegisterServerFunctions(CSquirrelVM* pSquirrelVM)
|
||||
|
||||
Script_RegisterFunction(pSquirrelVM, "BanPlayerByName", "Script_BanPlayerByName", "Bans a player from the server by name", "void", "string", &VSquirrel::SERVER::BanPlayerByName);
|
||||
Script_RegisterFunction(pSquirrelVM, "BanPlayerById", "Script_BanPlayerById", "Bans a player from the server by handle or nucleus id", "void", "string", &VSquirrel::SERVER::BanPlayerById);
|
||||
|
||||
Script_RegisterFunction(pSquirrelVM, "UnbanPlayer", "Script_UnbanPlayer", "Unbans a player from the server by nucleus id or ip address", "void", "string", &VSquirrel::SERVER::UnbanPlayer);
|
||||
}
|
||||
#endif // !CLIENT_DLL
|
||||
|
||||
|
@ -167,47 +167,7 @@ void Host_Unban_f(const CCommand& args)
|
||||
return;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
if (args.HasOnlyDigits(1)) // Check if we have an ip address or nucleus id.
|
||||
{
|
||||
if (g_pBanSystem->DeleteEntry("noIP", std::stoll(args.Arg(1)))) // Delete ban entry.
|
||||
{
|
||||
g_pBanSystem->Save(); // Save modified vector to file.
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (g_pBanSystem->DeleteEntry(args.Arg(1), 0)) // Delete ban entry.
|
||||
{
|
||||
g_pBanSystem->Save(); // Save modified vector to file.
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (const std::exception& e)
|
||||
{
|
||||
Error(eDLL_T::SERVER, NO_ERROR, "%s - %s", __FUNCTION__, e.what());
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
=====================
|
||||
Host_Changelevel_f
|
||||
|
||||
Goes to a new map,
|
||||
taking all clients along
|
||||
=====================
|
||||
*/
|
||||
void Host_Changelevel_f(const CCommand& args)
|
||||
{
|
||||
if (args.ArgC() >= 2
|
||||
&& IsOriginInitialized()
|
||||
&& g_pServer->IsActive())
|
||||
{
|
||||
v_SetLaunchOptions(args);
|
||||
v_HostState_ChangeLevelMP(args[1], args[2]);
|
||||
}
|
||||
g_pBanSystem->UnbanPlayer(args.Arg(1));
|
||||
}
|
||||
|
||||
/*
|
||||
@ -231,6 +191,25 @@ void Host_ReloadPlaylists_f(const CCommand& args)
|
||||
KeyValues::InitPlaylists(); // Re-Init playlist.
|
||||
}
|
||||
|
||||
/*
|
||||
=====================
|
||||
Host_Changelevel_f
|
||||
|
||||
Goes to a new map,
|
||||
taking all clients along
|
||||
=====================
|
||||
*/
|
||||
void Host_Changelevel_f(const CCommand& args)
|
||||
{
|
||||
if (args.ArgC() >= 2
|
||||
&& IsOriginInitialized()
|
||||
&& g_pServer->IsActive())
|
||||
{
|
||||
v_SetLaunchOptions(args);
|
||||
v_HostState_ChangeLevelMP(args[1], args[2]);
|
||||
}
|
||||
}
|
||||
|
||||
#endif // !CLIENT_DLL
|
||||
/*
|
||||
=====================
|
||||
|
@ -21,9 +21,9 @@ void Host_KickID_f(const CCommand& args);
|
||||
void Host_Ban_f(const CCommand& args);
|
||||
void Host_BanID_f(const CCommand& args);
|
||||
void Host_Unban_f(const CCommand& args);
|
||||
void Host_Changelevel_f(const CCommand& args);
|
||||
void Host_ReloadBanList_f(const CCommand& args);
|
||||
void Host_ReloadPlaylists_f(const CCommand& args);
|
||||
void Host_Changelevel_f(const CCommand& args);
|
||||
#endif // !CLIENT_DLL
|
||||
void Pak_ListPaks_f(const CCommand& args);
|
||||
void Pak_RequestUnload_f(const CCommand& args);
|
||||
|
Loading…
x
Reference in New Issue
Block a user