2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-16 16:48:13 +03:00

Cvars for command flood punishments (#230)

* Cvars for command flood punishments

Could we get something like this in the next build?

* Update rehlds_security.cpp
This commit is contained in:
spark512 2016-07-30 17:55:24 +02:00 committed by theAsmodai
parent 78213296fc
commit 383e805356

View File

@ -5,6 +5,11 @@ cvar_t sv_rehlds_movecmdrate_max_burst = { "sv_rehlds_movecmdrate_max_burst", "2
cvar_t sv_rehlds_stringcmdrate_max_avg = {"sv_rehlds_stringcmdrate_max_avg", "80", 0, 80.0f, NULL}; cvar_t sv_rehlds_stringcmdrate_max_avg = {"sv_rehlds_stringcmdrate_max_avg", "80", 0, 80.0f, NULL};
cvar_t sv_rehlds_stringcmdrate_max_burst = {"sv_rehlds_stringcmdrate_max_burst", "400", 0, 400.0f, NULL}; cvar_t sv_rehlds_stringcmdrate_max_burst = {"sv_rehlds_stringcmdrate_max_burst", "400", 0, 400.0f, NULL};
cvar_t sv_rehlds_movecmdrate_avg_punish = { "sv_rehlds_movecmdrate_avg_punish", "5", 0, 5.0f, NULL };
cvar_t sv_rehlds_movecmdrate_burst_punish = { "sv_rehlds_movecmdrate_burst_punish", "5", 0, 5.0f, NULL };
cvar_t sv_rehlds_stringcmdrate_avg_punish = {"sv_rehlds_stringcmdrate_avg_punish", "5", 0, 5.0f, NULL};
cvar_t sv_rehlds_stringcmdrate_burst_punish = {"sv_rehlds_stringcmdrate_burst_punish", "5", 0, 5.0f, NULL};
CMoveCommandRateLimiter g_MoveCommandRateLimiter; CMoveCommandRateLimiter g_MoveCommandRateLimiter;
CStringCommandsRateLimiter g_StringCommandsRateLimiter; CStringCommandsRateLimiter g_StringCommandsRateLimiter;
@ -56,8 +61,13 @@ void CMoveCommandRateLimiter::CheckBurstRate(unsigned int clientId) {
dt = 0.2; //small intervals may give too high rates dt = 0.2; //small intervals may give too high rates
} }
if ((m_CurrentMoveCmds[clientId] / dt) > sv_rehlds_movecmdrate_max_burst.value) { if ((m_CurrentMoveCmds[clientId] / dt) > sv_rehlds_movecmdrate_max_burst.value) {
Cbuf_AddText(va("addip %i %s\n", 5, NET_BaseAdrToString(cl->netchan.remote_address))); if(sv_rehlds_movecmdrate_burst_punish.value < 0) {
SV_DropClient(cl, false, "Banned for move commands flooding (burst)"); SV_DropClient(cl, false, "Kicked for move commands flooding (burst)");
}
else {
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_movecmdrate_burst_punish.value, NET_BaseAdrToString(cl->netchan.remote_address)));
SV_DropClient(cl, false, "Banned for move commands flooding (burst)");
}
} }
} }
@ -68,8 +78,13 @@ void CMoveCommandRateLimiter::CheckAverageRate(unsigned int clientId) {
} }
if (m_AverageMoveCmdRate[clientId] > sv_rehlds_movecmdrate_max_avg.value) { if (m_AverageMoveCmdRate[clientId] > sv_rehlds_movecmdrate_max_avg.value) {
Cbuf_AddText(va("addip %i %s\n", 5, NET_BaseAdrToString(cl->netchan.remote_address))); if(sv_rehlds_movecmdrate_avg_punish.value < 0) {
SV_DropClient(cl, false, "Banned for move commands flooding (Avg)"); SV_DropClient(cl, false, "Kicked for move commands flooding (Avg)");
}
else {
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_movecmdrate_avg_punish.value, NET_BaseAdrToString(cl->netchan.remote_address)));
SV_DropClient(cl, false, "Banned for move commands flooding (Avg)");
}
} }
} }
@ -121,8 +136,13 @@ void CStringCommandsRateLimiter::CheckBurstRate(unsigned int clientId) {
dt = 0.2; //small intervals may give too high rates dt = 0.2; //small intervals may give too high rates
} }
if ((m_CurrentStringCmds[clientId] / dt) > sv_rehlds_stringcmdrate_max_burst.value) { if ((m_CurrentStringCmds[clientId] / dt) > sv_rehlds_stringcmdrate_max_burst.value) {
Cbuf_AddText(va("addip %i %s\n", 5, NET_BaseAdrToString(cl->netchan.remote_address))); if(sv_rehlds_stringcmdrate_burst_punish.value < 0) {
SV_DropClient(cl, false, "Banned for string commands flooding (burst)"); SV_DropClient(cl, false, "Kicked for string commands flooding (burst)");
}
else {
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_stringcmdrate_burst_punish.value, NET_BaseAdrToString(cl->netchan.remote_address)));
SV_DropClient(cl, false, "Banned for string commands flooding (burst)");
}
} }
} }
@ -133,8 +153,13 @@ void CStringCommandsRateLimiter::CheckAverageRate(unsigned int clientId) {
} }
if (m_AverageStringCmdRate[clientId] > sv_rehlds_stringcmdrate_max_avg.value) { if (m_AverageStringCmdRate[clientId] > sv_rehlds_stringcmdrate_max_avg.value) {
Cbuf_AddText(va("addip %i %s\n", 5, NET_BaseAdrToString(cl->netchan.remote_address))); if(sv_rehlds_stringcmdrate_avg_punish.value < 0) {
SV_DropClient(cl, false, "Banned for string commands flooding (Avg)"); SV_DropClient(cl, false, "Kicked for string commands flooding (Avg)");
}
else {
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_stringcmdrate_avg_punish.value, NET_BaseAdrToString(cl->netchan.remote_address)));
SV_DropClient(cl, false, "Banned for string commands flooding (Avg)");
}
} }
} }
@ -162,4 +187,4 @@ void Rehlds_Security_ClientConnected(unsigned int clientId) {
g_MoveCommandRateLimiter.ClientConnected(clientId); g_MoveCommandRateLimiter.ClientConnected(clientId);
g_StringCommandsRateLimiter.ClientConnected(clientId); g_StringCommandsRateLimiter.ClientConnected(clientId);
#endif #endif
} }