2023-02-02 00:19:27 +01:00
# pragma semicolon 1
# define PLUGIN_AUTHOR "jenz"
# define g_dLength 400
# define PLUGIN_VERSION "1.0"
# pragma newdecls required
# include <sourcemod>
2023-02-14 21:29:45 +01:00
# include <sourcebanspp>
2023-02-02 00:19:27 +01:00
# include <clientprefs>
# include <cstrike>
# include <sdktools>
Database g_dDatabase ;
2023-02-03 11:38:47 +01:00
Handle g_hOnReportBanPostForward ;
2023-02-02 00:19:27 +01:00
public Plugin myinfo =
{
name = " jenz ban detector " ,
author = PLUGIN_AUTHOR ,
description = " my ban detector maybe catches you " ,
version = PLUGIN_VERSION ,
url = " www.unloze.com "
} ;
2023-02-03 11:38:47 +01:00
public APLRes AskPluginLoad2 ( Handle myself , bool late , char [ ] error , int err_max )
{
RegPluginLibrary ( " jenz_ban_detector " ) ;
return APLRes_Success ;
}
2023-02-02 00:19:27 +01:00
public void OnPluginStart ( )
{
2023-02-03 11:38:47 +01:00
g_hOnReportBanPostForward = CreateGlobalForward ( " BanDetectorPost " , ET_Ignore , Param_Cell , Param_String ) ;
2023-02-02 00:19:27 +01:00
if ( ! g_dDatabase )
{
Database . Connect ( SQL_OnDatabaseConnect , " jenz_ban_detector " ) ;
}
2023-08-01 22:15:35 +02:00
}
public void OnMapStart ( )
{
if ( ! g_dDatabase )
2023-02-02 00:19:27 +01:00
{
2023-08-01 22:15:35 +02:00
Database . Connect ( SQL_OnDatabaseConnect , " jenz_ban_detector " ) ;
}
}
public void SQL_OnDatabaseConnect ( Database db , const char [ ] error , any data )
{
if ( ! db | | strlen ( error ) )
{
LogError ( " Database error: %s " , error ) ;
return ;
}
g_dDatabase = db ;
}
public void OnClientPostAdminCheck ( int client )
{
if ( ! IsFakeClient ( client ) & & ! IsClientSourceTV ( client ) )
{
SQL_addEntry ( client ) ;
CreateTimer ( 15.0 , SQL_Select_fingerprints , GetClientSerial ( client ) ) ;
2023-02-02 00:19:27 +01:00
}
}
2023-02-07 20:45:15 +01:00
public void SQL_addEntry ( int client )
2023-02-02 00:19:27 +01:00
{
char sQuery [ g_dLength ] ;
char sSID [ MAX_NAME_LENGTH ] ;
char sIP [ MAX_NAME_LENGTH ] ;
char sName [ MAX_NAME_LENGTH ] ;
GetClientName ( client , sName , sizeof ( sName ) ) ;
int size2 = 2 * strlen ( sName ) + 1 ;
char [ ] sEscapedName = new char [ size2 + 1 ] ;
GetClientAuthId ( client , AuthId_Steam2 , sSID , sizeof ( sSID ) ) ;
g_dDatabase . Escape ( sName , sEscapedName , size2 + 1 ) ;
GetClientIP ( client , sIP , sizeof ( sIP ) ) ;
2023-08-01 22:15:35 +02:00
Format ( sQuery , sizeof ( sQuery ) , " insert ignore into `ban_detector` (`steamid`, `ip`, `name`) SELECT '%s', '%s','%s' " , sSID , sIP , sEscapedName ) ;
2023-04-30 12:14:28 +02:00
g_dDatabase . Query ( SQL_UpdateEntry , sQuery , GetClientSerial ( client ) , DBPrio_Low ) ;
2023-02-02 00:19:27 +01:00
}
2023-08-01 22:15:35 +02:00
public void SQL_UpdateEntry ( Database db , DBResultSet results , const char [ ] error , int Serial )
2023-02-02 00:19:27 +01:00
{
if ( ! db | | strlen ( error ) )
{
LogError ( " Database error: %s " , error ) ;
2023-08-01 22:15:35 +02:00
delete results ;
2023-02-02 00:19:27 +01:00
return ;
}
2023-08-01 22:15:35 +02:00
int client ;
if ( ( client = GetClientFromSerial ( Serial ) ) = = 0 )
{
delete results ;
return ;
}
if ( IsValidClient ( client ) )
{
char sQuery [ g_dLength ] ;
char sSID [ MAX_NAME_LENGTH ] ;
GetClientAuthId ( client , AuthId_Steam2 , sSID , sizeof ( sSID ) ) ;
Format ( sQuery , sizeof ( sQuery ) , " UPDATE ban_detector SET last_connect = now() where steamid = '%s' " , sSID ) ;
g_dDatabase . Query ( SQL_update_last_connect , sQuery , GetClientSerial ( client ) , DBPrio_Low ) ;
}
delete results ;
2023-02-02 00:19:27 +01:00
}
2023-08-01 22:15:35 +02:00
public void SQL_update_last_connect ( Database db , DBResultSet results , const char [ ] error , int Serial )
2023-02-02 00:19:27 +01:00
{
if ( ! db | | strlen ( error ) )
{
LogError ( " Database error: %s " , error ) ;
2023-04-30 12:14:28 +02:00
delete results ;
return ;
}
2023-08-01 22:15:35 +02:00
delete results ;
}
public Action SQL_Select_fingerprints ( Handle hTimer , int Serial )
{
int client ;
2023-04-30 12:14:28 +02:00
if ( ( client = GetClientFromSerial ( Serial ) ) = = 0 )
{
2023-02-02 00:19:27 +01:00
return ;
}
2023-02-03 01:44:45 +01:00
if ( IsValidClient ( client ) )
{
char sQuery [ g_dLength ] ;
char sSID [ MAX_NAME_LENGTH ] ;
2023-02-07 20:45:15 +01:00
char sIP [ MAX_NAME_LENGTH ] ;
GetClientIP ( client , sIP , sizeof ( sIP ) ) ;
2023-02-03 01:44:45 +01:00
GetClientAuthId ( client , AuthId_Steam2 , sSID , sizeof ( sSID ) ) ;
2023-08-01 22:15:35 +02:00
Format ( sQuery , sizeof ( sQuery ) , " select fingerprint from ban_detector.ban_detector where steamid = '%s' " , sSID ) ;
2023-02-03 01:44:45 +01:00
//PrintToChatAll("sQuery: %s", sQuery);
2023-04-30 12:14:28 +02:00
g_dDatabase . Query ( SQL_FindFingerPrints , sQuery , GetClientSerial ( client ) , DBPrio_Low ) ;
2023-02-03 01:44:45 +01:00
}
}
2023-04-30 12:14:28 +02:00
public void SQL_FindFingerPrints ( Database db , DBResultSet results , const char [ ] error , int Serial )
2023-02-03 01:44:45 +01:00
{
if ( ! db | | strlen ( error ) )
{
LogError ( " Database error: %s " , error ) ;
2023-04-30 12:14:28 +02:00
delete results ;
return ;
}
int client ;
if ( ( client = GetClientFromSerial ( Serial ) ) = = 0 )
{
delete results ;
return ;
}
if ( ! IsValidClient ( client ) )
{
delete results ;
2023-02-03 01:44:45 +01:00
return ;
}
2023-06-20 23:47:39 +02:00
2023-06-25 17:21:34 +02:00
//god knows how big this might need to be
char sQuery [ 4344 ] ;
2023-08-01 22:15:35 +02:00
//cant rely on IP cause several chinese players share VPN and end up with same IP despite clearly being different people.
Format ( sQuery , sizeof ( sQuery ) , " select sb.authid from ban_detector.ban_detector bd inner join unloze_sourceban.sb_bans sb on sb.authid = bd.steamid where fingerprint in ( " ) ;
2023-06-20 23:47:39 +02:00
bool first = true ;
2023-02-07 20:45:15 +01:00
while ( results . RowCount > 0 & & results . FetchRow ( ) )
2023-02-03 01:44:45 +01:00
{
2023-06-20 23:47:39 +02:00
char fingerprint [ 1024 ] ;
2023-02-03 01:44:45 +01:00
results . FetchString ( 0 , fingerprint , sizeof ( fingerprint ) ) ;
char [ ] sEscapedFingerPrint = new char [ 1024 ] ;
g_dDatabase . Escape ( fingerprint , sEscapedFingerPrint , 1024 ) ;
2023-06-20 23:47:39 +02:00
if ( first )
{
Format ( sEscapedFingerPrint , 1024 , " '%s' " , sEscapedFingerPrint ) ;
}
else
2023-02-07 20:45:15 +01:00
{
2023-06-20 23:47:39 +02:00
Format ( sEscapedFingerPrint , 1024 , " ,'%s' " , sEscapedFingerPrint ) ;
2023-02-07 20:45:15 +01:00
}
2023-06-20 23:47:39 +02:00
StrCat ( sQuery , sizeof ( sQuery ) , sEscapedFingerPrint ) ;
first = false ;
2023-02-03 01:44:45 +01:00
}
2023-06-25 17:21:34 +02:00
StrCat ( sQuery , sizeof ( sQuery ) , " ) and (RemoveType != 'U' or RemoveType is NULL) and (ends > UNIX_TIMESTAMP() + 3600 or ends = created) order by created desc limit 1 " ) ;
//LogError("LOOK HERE: %s", sQuery);
if ( ! first )
2023-02-03 01:44:45 +01:00
{
2023-06-25 17:21:34 +02:00
g_dDatabase . Query ( sql_select_sb_bans , sQuery , GetClientSerial ( client ) , DBPrio_Low ) ;
2023-06-20 23:47:39 +02:00
}
2023-02-03 01:44:45 +01:00
delete results ;
}
2023-04-30 12:14:28 +02:00
public void sql_select_sb_bans ( Database db , DBResultSet results , const char [ ] error , int Serial )
2023-02-03 01:44:45 +01:00
{
if ( ! db | | strlen ( error ) )
{
2023-04-30 12:14:28 +02:00
delete results ;
2023-06-25 17:21:34 +02:00
LogError ( " Database error 2: %s " , error ) ;
2023-02-03 01:44:45 +01:00
return ;
}
2023-04-30 12:14:28 +02:00
int client ;
if ( ( client = GetClientFromSerial ( Serial ) ) = = 0 )
{
delete results ;
return ;
}
2023-02-03 01:44:45 +01:00
if ( ! IsValidClient ( client ) )
{
delete results ;
return ;
}
2023-08-01 22:15:35 +02:00
if ( results . RowCount & & results . FetchRow ( ) & & IsValidClient ( client ) )
2023-02-03 01:44:45 +01:00
{
char sSID [ MAX_NAME_LENGTH ] ;
results . FetchString ( 0 , sSID , sizeof ( sSID ) ) ;
2023-02-03 11:38:47 +01:00
Call_StartForward ( g_hOnReportBanPostForward ) ;
Call_PushCell ( client ) ;
2023-08-01 22:15:35 +02:00
Call_PushString ( sSID ) ;
2023-02-03 11:38:47 +01:00
Call_Finish ( ) ;
2023-02-14 21:29:45 +01:00
//bans need to be over 1 hour long for getting detected
2023-08-01 22:15:35 +02:00
char message [ 1024 ] ;
Format ( message , sizeof ( message ) , " Ban avoiding (Jenz ban detector). SteamID avoiding ban: %s " , sSID ) ;
SBPP_BanPlayer ( 0 , client , 0 , message ) ;
2023-02-03 01:44:45 +01:00
}
delete results ;
2023-02-02 00:19:27 +01:00
}
stock bool IsValidClient ( int client )
{
2023-08-01 22:15:35 +02:00
if ( client > 0 & & client < = MaxClients & & IsClientConnected ( client ) & & IsClientInGame ( client ) & & ! IsFakeClient ( client ) )
return true ;
return false ;
2023-02-02 00:19:27 +01:00
}