From 7df45d32a20bdc8ef34632292330fee942b6b0d2 Mon Sep 17 00:00:00 2001 From: Rudolf Polzer Date: Sun, 8 Apr 2012 20:25:47 +0200 Subject: [PATCH] enforce bans on first clientcommand too, not just on ClientConnect --- qcsrc/server/cl_client.qc | 2 +- qcsrc/server/cl_player.qc | 3 --- qcsrc/server/command/cmd.qc | 4 ++++ qcsrc/server/ipban.qc | 9 +++++++++ 4 files changed, 14 insertions(+), 4 deletions(-) diff --git a/qcsrc/server/cl_client.qc b/qcsrc/server/cl_client.qc index 38007434e5..b68bce6949 100644 --- a/qcsrc/server/cl_client.qc +++ b/qcsrc/server/cl_client.qc @@ -1355,7 +1355,7 @@ void ClientConnect (void) return; } - if(Ban_MaybeEnforceBan(self)) + if(Ban_MaybeEnforceBanOnce(self)) return; DecodeLevelParms(); diff --git a/qcsrc/server/cl_player.qc b/qcsrc/server/cl_player.qc index fc9ef5f247..db2707fb9e 100644 --- a/qcsrc/server/cl_player.qc +++ b/qcsrc/server/cl_player.qc @@ -811,9 +811,6 @@ float Say(entity source, float teamsay, entity privatesay, string msgin, float f entity head; float ret; - if(Ban_MaybeEnforceBan(source)) - return 0; - if(!teamsay && !privatesay) if(substring(msgin, 0, 1) == " ") msgin = substring(msgin, 1, strlen(msgin) - 1); // work around DP say bug (say_team does not have this!) diff --git a/qcsrc/server/command/cmd.qc b/qcsrc/server/command/cmd.qc index e885c3054b..32bd688d3b 100644 --- a/qcsrc/server/command/cmd.qc +++ b/qcsrc/server/command/cmd.qc @@ -658,6 +658,10 @@ void ClientCommand_macro_write_aliases(float fh) void SV_ParseClientCommand(string command) { + // if we're banned, don't even parse the command + if(Ban_MaybeEnforceBanOnce(self)) + return; + float argc = tokenize_console(command); // for the mutator hook system diff --git a/qcsrc/server/ipban.qc b/qcsrc/server/ipban.qc index fc889ecf2d..f770dc513e 100644 --- a/qcsrc/server/ipban.qc +++ b/qcsrc/server/ipban.qc @@ -448,6 +448,15 @@ float Ban_MaybeEnforceBan(entity client) return FALSE; } +.float ban_checked; +float Ban_MaybeEnforceBanOnce(entity client) +{ + if(client.ban_checked) + return FALSE; + client.ban_checked = TRUE; + return Ban_MaybeEnforceBan(self); +} + string Ban_Enforce(float i, string reason) { string s; -- 2.39.2