2
0
mirror of https://github.com/rehlds/rehlds.git synced 2025-01-17 00:58:18 +03:00

Merge pull request #235 from Adidasman1/master

Fix already spawn and add cvar rehlds_security.
This commit is contained in:
theAsmodai 2016-08-12 17:27:06 +03:00 committed by GitHub
commit f18dbc8ce1
7 changed files with 54 additions and 14 deletions

View File

@ -47,7 +47,7 @@ Bugfixed version of rehlds contains an additional cvars:
<li>sv_rehlds_stringcmdrate_max_avg // Max average level of 'string' cmds for ban. Default: 80 <li>sv_rehlds_stringcmdrate_max_avg // Max average level of 'string' cmds for ban. Default: 80
<li>sv_rehlds_stringcmdrate_avg_punish // Time in minutes for which the player will be banned (0 - Permanent, use a negative number for a kick). Default: 5 <li>sv_rehlds_stringcmdrate_avg_punish // Time in minutes for which the player will be banned (0 - Permanent, use a negative number for a kick). Default: 5
<li>sv_rehlds_stringcmdrate_max_burst // Max burst level of 'string' cmds for ban. Default: 400 <li>sv_rehlds_stringcmdrate_max_burst // Max burst level of 'string' cmds for ban. Default: 400
<li>sv_rehldsstringcmdrate_burst_punish // Time in minutes for which the player will be banned (0 - Permanent, use a negative number for a kick). Default: 5 <li>sv_rehlds_stringcmdrate_burst_punish // Time in minutes for which the player will be banned (0 - Permanent, use a negative number for a kick). Default: 5
<li>sv_rehlds_userinfo_transmitted_fields // Userinfo fields only with these keys will be transmitted to clients via network. If not set then all fields will be transmitted (except prefixed with underscore). Each key must be prefixed by backslash, for example "\name\model\*sid\*hltv\bottomcolor\topcolor". Default: "" <li>sv_rehlds_userinfo_transmitted_fields // Userinfo fields only with these keys will be transmitted to clients via network. If not set then all fields will be transmitted (except prefixed with underscore). Each key must be prefixed by backslash, for example "\name\model\*sid\*hltv\bottomcolor\topcolor". Default: ""
</ul> </ul>

View File

@ -570,7 +570,6 @@ void Host_Status_f(void)
qboolean bConnectedToSteam3; qboolean bConnectedToSteam3;
const char *pchConnectionString = ""; const char *pchConnectionString = "";
const char *pchSteamUniverse = ""; const char *pchSteamUniverse = "";
char szfile[260];
if (cmd_source == src_command) if (cmd_source == src_command)
{ {
@ -583,12 +582,15 @@ void Host_Status_f(void)
} }
} }
#ifndef REHLDS_FIXES // Remove Useless Stuff
char szfile[260];
if (Cmd_Argc() == 2 && !Q_stricmp(Cmd_Argv(1), "log")) if (Cmd_Argc() == 2 && !Q_stricmp(Cmd_Argv(1), "log"))
{ {
log = TRUE; log = TRUE;
Q_snprintf(szfile, sizeof(szfile), "%s", "status.log"); Q_snprintf(szfile, sizeof(szfile), "%s", "status.log");
_unlink(szfile); _unlink(szfile);
} }
#endif // REHLDS_FIXES
Host_Status_Printf(conprint, log, "hostname: %s\n", Cvar_VariableString("hostname")); Host_Status_Printf(conprint, log, "hostname: %s\n", Cvar_VariableString("hostname"));

View File

@ -1060,7 +1060,11 @@ qboolean NET_QueuePacket(netsrc_t sock)
} }
else else
{ {
#ifdef REHLDS_FIXES
Con_DPrintf("Invalid split packet length %i\n", in_message.cursize);
#else
Con_Printf("Invalid split packet length %i\n", in_message.cursize); Con_Printf("Invalid split packet length %i\n", in_message.cursize);
#endif
return FALSE; return FALSE;
} }
} }

View File

@ -1690,6 +1690,14 @@ void EXT_FUNC SV_Spawn_f_internal(void)
return; return;
} }
#ifdef REHLDS_FIXES
// Is already spawn
if (host_client->spawned)
{
return;
}
#endif // REHLDS_FIXES
host_client->crcValue = Q_atoi(Cmd_Argv(2)); host_client->crcValue = Q_atoi(Cmd_Argv(2));
COM_UnMunge2((unsigned char *)&host_client->crcValue, 4, (-1 - g_psvs.spawncount) & 0xFF); COM_UnMunge2((unsigned char *)&host_client->crcValue, 4, (-1 - g_psvs.spawncount) & 0xFF);

View File

@ -53,7 +53,11 @@ qboolean nofind;
*/ */
#ifndef HOOK_ENGINE #ifndef HOOK_ENGINE
#if defined(SWDS) && defined(REHLDS_FIXES)
command_t clcommands[] = { "status", "name", "kill", "pause", "spawn", "new", "sendres", "dropclient", "kick", "ping", "dlfile", "setinfo", "sendents", "fullupdate", "setpause", "unpause", NULL };
#else
command_t clcommands[23] = { "status", "god", "notarget", "fly", "name", "noclip", "kill", "pause", "spawn", "new", "sendres", "dropclient", "kick", "ping", "dlfile", "nextdl", "setinfo", "showinfo", "sendents", "fullupdate", "setpause", "unpause", NULL }; command_t clcommands[23] = { "status", "god", "notarget", "fly", "name", "noclip", "kill", "pause", "spawn", "new", "sendres", "dropclient", "kick", "ping", "dlfile", "nextdl", "setinfo", "showinfo", "sendents", "fullupdate", "setpause", "unpause", NULL };
#endif
cvar_t sv_edgefriction = { "edgefriction", "2", FCVAR_SERVER, 0.0f, NULL }; cvar_t sv_edgefriction = { "edgefriction", "2", FCVAR_SERVER, 0.0f, NULL };
cvar_t sv_maxspeed = { "sv_maxspeed", "320", FCVAR_SERVER, 0.0f, NULL }; cvar_t sv_maxspeed = { "sv_maxspeed", "320", FCVAR_SERVER, 0.0f, NULL };
@ -1817,7 +1821,12 @@ void SV_ShowServerinfo_f(void)
} }
else else
{ {
#ifdef REHLDS_FIXES
// fix print message client console
SV_ClientPrintf(Info_Serverinfo());
#else
Info_Print(Info_Serverinfo()); Info_Print(Info_Serverinfo());
#endif // REHLDS_FIXES
} }
} }

View File

@ -280,7 +280,7 @@ struct RehldsFuncs_t {
void(*Steam_NotifyClientDisconnect)(IGameClient* cl); void(*Steam_NotifyClientDisconnect)(IGameClient* cl);
void(*SV_StartSound)(int recipients, edict_t *entity, int channel, const char *sample, int volume, float attenuation, int flags, int pitch); void(*SV_StartSound)(int recipients, edict_t *entity, int channel, const char *sample, int volume, float attenuation, int flags, int pitch);
bool(*SV_EmitSound2)(edict_t *entity, IGameClient *receiver, int channel, const char *sample, float volume, float attenuation, int flags, int pitch, int emitFlags, const float *pOrigin); bool(*SV_EmitSound2)(edict_t *entity, IGameClient *receiver, int channel, const char *sample, float volume, float attenuation, int flags, int pitch, int emitFlags, const float *pOrigin);
void (* SV_UpdateUserInfo)(IGameClient *pGameClient); void(*SV_UpdateUserInfo)(IGameClient *pGameClient);
}; };
class IRehldsApi { class IRehldsApi {

View File

@ -1,14 +1,14 @@
#include "precompiled.h" #include "precompiled.h"
cvar_t sv_rehlds_movecmdrate_max_avg = { "sv_rehlds_movecmdrate_max_avg", "400", 0, 400.0f, NULL }; cvar_t sv_rehlds_movecmdrate_max_avg = { "sv_rehlds_movecmdrate_max_avg", "1800", 0, 1800.0f, NULL };
cvar_t sv_rehlds_movecmdrate_max_burst = { "sv_rehlds_movecmdrate_max_burst", "2500", 0, 2500.0f, NULL }; cvar_t sv_rehlds_movecmdrate_max_burst = { "sv_rehlds_movecmdrate_max_burst", "5500", 0, 5500.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_avg = { "sv_rehlds_stringcmdrate_max_avg", "250", 0, 250.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", "500", 0, 500.0f, NULL };
cvar_t sv_rehlds_movecmdrate_avg_punish = { "sv_rehlds_movecmdrate_avg_punish", "5", 0, 5.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_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_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}; 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;
@ -62,9 +62,12 @@ void CMoveCommandRateLimiter::CheckBurstRate(unsigned int clientId) {
} }
if ((m_CurrentMoveCmds[clientId] / dt) > sv_rehlds_movecmdrate_max_burst.value) { if ((m_CurrentMoveCmds[clientId] / dt) > sv_rehlds_movecmdrate_max_burst.value) {
if(sv_rehlds_movecmdrate_burst_punish.value < 0) { if(sv_rehlds_movecmdrate_burst_punish.value < 0) {
Con_DPrintf("%s Kicked for move commands flooding (burst) (%.1f)\n", cl->name, (m_CurrentMoveCmds[clientId] / dt));
SV_DropClient(cl, false, "Kicked for move commands flooding (burst)"); SV_DropClient(cl, false, "Kicked for move commands flooding (burst)");
} }
else { else
{
Con_DPrintf("%s Banned for move commands flooding (burst) (%.1f)\n", cl->name, (m_CurrentMoveCmds[clientId] / dt));
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_movecmdrate_burst_punish.value, NET_BaseAdrToString(cl->netchan.remote_address))); 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)"); SV_DropClient(cl, false, "Banned for move commands flooding (burst)");
} }
@ -76,12 +79,15 @@ void CMoveCommandRateLimiter::CheckAverageRate(unsigned int clientId) {
if (!cl->active || sv_rehlds_movecmdrate_max_burst.value <= 0.0f) { if (!cl->active || sv_rehlds_movecmdrate_max_burst.value <= 0.0f) {
return; return;
} }
if (m_AverageMoveCmdRate[clientId] > sv_rehlds_movecmdrate_max_avg.value) { if (m_AverageMoveCmdRate[clientId] > sv_rehlds_movecmdrate_max_avg.value) {
if(sv_rehlds_movecmdrate_avg_punish.value < 0) { if(sv_rehlds_movecmdrate_avg_punish.value < 0) {
Con_DPrintf("%s Kicked for move commands flooding (Avg) (%.1f)\n", cl->name, m_AverageMoveCmdRate[clientId]);
SV_DropClient(cl, false, "Kicked for move commands flooding (Avg)"); SV_DropClient(cl, false, "Kicked for move commands flooding (Avg)");
} }
else { else
{
Con_DPrintf("%s Banned for move commands flooding (Avg) (%.1f)\n", cl->name, m_AverageMoveCmdRate[clientId]);
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_movecmdrate_avg_punish.value, NET_BaseAdrToString(cl->netchan.remote_address))); 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)"); SV_DropClient(cl, false, "Banned for move commands flooding (Avg)");
} }
@ -137,9 +143,12 @@ void CStringCommandsRateLimiter::CheckBurstRate(unsigned int clientId) {
} }
if ((m_CurrentStringCmds[clientId] / dt) > sv_rehlds_stringcmdrate_max_burst.value) { if ((m_CurrentStringCmds[clientId] / dt) > sv_rehlds_stringcmdrate_max_burst.value) {
if(sv_rehlds_stringcmdrate_burst_punish.value < 0) { if(sv_rehlds_stringcmdrate_burst_punish.value < 0) {
Con_DPrintf("%s Kicked for string commands flooding (burst) (%.1f)\n", cl->name, (m_CurrentStringCmds[clientId] / dt));
SV_DropClient(cl, false, "Kicked for string commands flooding (burst)"); SV_DropClient(cl, false, "Kicked for string commands flooding (burst)");
} }
else { else
{
Con_DPrintf("%s Banned for string commands flooding (burst) (%.1f)\n", cl->name, (m_CurrentStringCmds[clientId] / dt));
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_stringcmdrate_burst_punish.value, NET_BaseAdrToString(cl->netchan.remote_address))); 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)"); SV_DropClient(cl, false, "Banned for string commands flooding (burst)");
} }
@ -154,9 +163,12 @@ 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) {
if(sv_rehlds_stringcmdrate_avg_punish.value < 0) { if(sv_rehlds_stringcmdrate_avg_punish.value < 0) {
Con_DPrintf("%s Kicked for string commands flooding (Avg) (%.1f)\n", cl->name, m_AverageStringCmdRate[clientId]);
SV_DropClient(cl, false, "Kicked for string commands flooding (Avg)"); SV_DropClient(cl, false, "Kicked for string commands flooding (Avg)");
} }
else { else
{
Con_DPrintf("%s Banned for string commands flooding (Avg) (%.1f)\n", cl->name, m_AverageStringCmdRate[clientId]);
Cbuf_AddText(va("addip %.1f %s\n", sv_rehlds_stringcmdrate_avg_punish.value, NET_BaseAdrToString(cl->netchan.remote_address))); 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)"); SV_DropClient(cl, false, "Banned for string commands flooding (Avg)");
} }
@ -169,6 +181,11 @@ void Rehlds_Security_Init() {
Cvar_RegisterVariable(&sv_rehlds_movecmdrate_max_burst); Cvar_RegisterVariable(&sv_rehlds_movecmdrate_max_burst);
Cvar_RegisterVariable(&sv_rehlds_stringcmdrate_max_avg); Cvar_RegisterVariable(&sv_rehlds_stringcmdrate_max_avg);
Cvar_RegisterVariable(&sv_rehlds_stringcmdrate_max_burst); Cvar_RegisterVariable(&sv_rehlds_stringcmdrate_max_burst);
Cvar_RegisterVariable(&sv_rehlds_movecmdrate_avg_punish);
Cvar_RegisterVariable(&sv_rehlds_movecmdrate_burst_punish);
Cvar_RegisterVariable(&sv_rehlds_stringcmdrate_avg_punish);
Cvar_RegisterVariable(&sv_rehlds_stringcmdrate_burst_punish);
#endif #endif
} }