From 698c848f87be2a03a806cb45ff2cce66ed293901 Mon Sep 17 00:00:00 2001 From: "M. Kristall" Date: Wed, 28 Oct 2009 14:54:50 +0000 Subject: * Fix a bug that would prevent banning by name in most cases * When banning by name and there are multiple matches, do not print every match for a given player * The message indicating a ban hit has been updated * Match namelog entries to players only by GUID, allowing for a single player reconnecting from a different IP address * Remove the remaining GUID stub display --- src/game/g_admin.c | 169 ++++++++++++++++++++++++++++++++--------------------- src/game/g_admin.h | 5 +- 2 files changed, 107 insertions(+), 67 deletions(-) (limited to 'src') diff --git a/src/game/g_admin.c b/src/game/g_admin.c index 81f7d1e6..e2cbfc76 100644 --- a/src/game/g_admin.c +++ b/src/game/g_admin.c @@ -788,9 +788,10 @@ qboolean G_admin_ban_check( gentity_t *ent, char *reason, int rlen ) ban->reason, duration ); - G_Printf( S_COLOR_YELLOW "%s" S_COLOR_YELLOW " tried to connect from %s " - "(ban #%d)\n", - ban->name, + G_Printf( S_COLOR_YELLOW "%s" S_COLOR_YELLOW + " at %s is banned (ban #%d)\n", + ent->client->pers.netname[ 0 ] ? ent->client->pers.netname : + ban->name, ent->client->pers.ip, i + 1 ); return qtrue; @@ -876,7 +877,7 @@ void G_admin_namelog_cleanup( ) void G_admin_namelog_update( gclient_t *client, qboolean disconnect ) { - int j; + int i; g_admin_namelog_t *n, *p = NULL; char n1[ MAX_NAME_LENGTH ]; char n2[ MAX_NAME_LENGTH ]; @@ -891,18 +892,27 @@ void G_admin_namelog_update( gclient_t *client, qboolean disconnect ) if( !disconnect && n->slot != clientNum && n->slot != -1 ) continue; - if( !Q_stricmp( client->pers.ip, n->ip ) && - !Q_stricmp( client->pers.guid, n->guid ) ) + if( !Q_stricmp( client->pers.guid, n->guid ) ) { - for( j = 0; j < MAX_ADMIN_NAMELOG_NAMES && n->name[ j ][ 0 ]; j++ ) + for( i = 0; i < MAX_ADMIN_NAMELOG_NAMES && n->name[ i ][ 0 ]; i++ ) { - G_SanitiseString( n->name[ j ], n2, sizeof( n2 ) ); + G_SanitiseString( n->name[ i ], n2, sizeof( n2 ) ); if( !strcmp( n1, n2 ) ) break; } - if( j == MAX_ADMIN_NAMELOG_NAMES ) - j = client->pers.nameChanges % MAX_ADMIN_NAMELOG_NAMES; - Q_strncpyz( n->name[ j ], client->pers.netname, sizeof( n->name[ j ] ) ); + if( i == MAX_ADMIN_NAMELOG_NAMES ) + i = client->pers.nameChanges % MAX_ADMIN_NAMELOG_NAMES; + Q_strncpyz( n->name[ i ], client->pers.netname, sizeof( n->name[ i ] ) ); + + for( i = 0; i < MAX_ADMIN_NAMELOG_ADDRS && n->ip[ i ][ 0 ]; i++ ) + { + if( !Q_stricmp( client->pers.ip, n->ip[ i ] ) ) + break; + } + if( i == MAX_ADMIN_NAMELOG_ADDRS ) + i--; + Q_strncpyz( n->ip[ i ], client->pers.ip, sizeof( n->ip[ i ] ) ); + n->slot = ( disconnect ) ? -1 : clientNum; // if this player is connecting, they are no longer banned @@ -913,7 +923,7 @@ void G_admin_namelog_update( gclient_t *client, qboolean disconnect ) } } n = BG_Alloc( sizeof( g_admin_namelog_t ) ); - Q_strncpyz( n->ip, client->pers.ip, sizeof( n->ip ) ); + Q_strncpyz( n->ip[ 0 ], client->pers.ip, sizeof( n->ip[ 0 ] ) ); Q_strncpyz( n->guid, client->pers.guid, sizeof( n->guid ) ); Q_strncpyz( n->name[ 0 ], client->pers.netname, sizeof( n->name[ 0 ] ) ); n->slot = ( disconnect ) ? -1 : clientNum; @@ -1454,7 +1464,7 @@ qboolean G_admin_ban( gentity_t *ent, int skiparg ) char *reason; char duration[ 13 ]; int logmatches = 0; - int i, j; + int i; qboolean exactmatch = qfalse; char n2[ MAX_NAME_LENGTH ]; char s2[ MAX_NAME_LENGTH ]; @@ -1531,31 +1541,38 @@ qboolean G_admin_ban( gentity_t *ent, int skiparg ) if( ipmatch ) { - if( G_AddressParse( namelog->ip, &cmp, NULL ) && - G_AddressCompare( &ip, &cmp, netmask ) ) + for( i = 0; i < MAX_ADMIN_NAMELOG_ADDRS && namelog->ip[ i ][ 0 ]; i++ ) { - logmatches++; - if( ( ip.type == IPv4 && netmask == 32 ) || - ( ip.type == IPv6 && netmask == 128 ) ) + if( G_AddressParse( namelog->ip[ i ], &cmp, NULL ) && + G_AddressCompare( &ip, &cmp, netmask ) ) { - exactmatch = qtrue; match = namelog; - break; + if( ( ip.type == IPv4 && netmask == 32 ) || + ( ip.type == IPv6 && netmask == 128 ) ) + { + exactmatch = qtrue; + break; + } } } - continue; + if( match ) + logmatches++; + if( exactmatch ) + break; } - for( j = 0; j < MAX_ADMIN_NAMELOG_NAMES && namelog->name[ j ][ 0 ]; j++ ) + else { - G_SanitiseString( namelog->name[ j ], n2, sizeof( n2 ) ); - if( strstr( n2, s2 ) ) + for( i = 0; i < MAX_ADMIN_NAMELOG_NAMES && namelog->name[ i ][ 0 ]; i++ ) { - match = namelog; - break; + G_SanitiseString( namelog->name[ i ], n2, sizeof( n2 ) ); + if( strstr( n2, s2 ) ) + { + match = namelog; + logmatches++; + break; + } } } - if( j < MAX_ADMIN_NAMELOG_NAMES ) - logmatches++; } if( !logmatches ) @@ -1569,16 +1586,21 @@ qboolean G_admin_ban( gentity_t *ent, int skiparg ) ADMBP( "^3!ban: ^7multiple recent clients match name, use IP or slot#:\n" ); for( namelog = g_admin_namelogs; namelog; namelog = namelog->next ) { - for( j = 0; j < MAX_ADMIN_NAMELOG_NAMES && namelog->name[ j ][ 0 ]; j++ ) + for( i = 0; i < MAX_ADMIN_NAMELOG_NAMES && namelog->name[ i ][ 0 ]; i++ ) { - G_SanitiseString( namelog->name[ j ], n2, sizeof( n2 ) ); + G_SanitiseString( namelog->name[ i ], n2, sizeof( n2 ) ); if( strstr( n2, s2 ) ) - { - ADMBP( va( "%s %15s ^7'%s^7'\n", - ( namelog->slot > -1 ) ? va( "^3%-2d", namelog->slot ) : "- ", - namelog->ip, - namelog->name[ j ] ) ); - } + break; + } + if( i < MAX_ADMIN_NAMELOG_NAMES && namelog->name[ i ][ 0 ] ) + { + ADMBP( namelog->slot > -1 ? + va( S_COLOR_YELLOW "%-2d" S_COLOR_WHITE, namelog->slot ) : "- " ); + for( i = 0; i < MAX_ADMIN_NAMELOG_NAMES && namelog->name[ i ][ 0 ]; i++ ) + ADMBP( va( " %s" S_COLOR_WHITE, namelog->name[ i ] ) ); + for( i = 0; i < MAX_ADMIN_NAMELOG_ADDRS && namelog->ip[ i ][ 0 ]; i++ ) + ADMBP( va( " %s", namelog->ip[ i ] ) ); + ADMBP( "\n" ); } } ADMBP_end(); @@ -1592,7 +1614,7 @@ qboolean G_admin_ban( gentity_t *ent, int skiparg ) " level than you\n" ); return qfalse; } - if( !strcmp( match->ip, "localhost" ) ) + if( !strcmp( match->ip[ 0 ], "localhost" ) ) { ADMP( "^3!ban: ^7disconnecting the host would end the game\n" ); return qfalse; @@ -1601,12 +1623,28 @@ qboolean G_admin_ban( gentity_t *ent, int skiparg ) G_admin_duration( ( seconds ) ? seconds : -1, duration, sizeof( duration ) ); - admin_create_ban( ent, - match->slot == -1 ? match->name[ 0 ] : - level.clients[ match->slot ].pers.netname, - match->guid, - ipmatch ? search : match->ip, - seconds, reason ); + if( ipmatch ) + { + admin_create_ban( ent, + match->slot == -1 ? match->name[ 0 ] : + level.clients[ match->slot ].pers.netname, + match->guid, + search, + seconds, reason ); + } + else + { + // ban all IP addresses used by this player + for( i = 0; i < MAX_ADMIN_NAMELOG_ADDRS && match->ip[ i ][ 0 ]; i++ ) + { + admin_create_ban( ent, + match->slot == -1 ? match->name[ 0 ] : + level.clients[ match->slot ].pers.netname, + match->guid, + match->ip[ i ], + seconds, reason ); + } + } match->banned = qtrue; @@ -2710,7 +2748,7 @@ qboolean G_admin_nextmap( gentity_t *ent, int skiparg ) qboolean G_admin_namelog( gentity_t *ent, int skiparg ) { - int j; + int i; char search[ MAX_NAME_LENGTH ] = {""}; char s2[ MAX_NAME_LENGTH ] = {""}; char n2[ MAX_NAME_LENGTH ] = {""}; @@ -2724,40 +2762,41 @@ qboolean G_admin_namelog( gentity_t *ent, int skiparg ) { G_SayArgv( 1 + skiparg, search, sizeof( search ) ); ipmatch = G_AddressParse( search, &a, &mask ); +G_Printf( "%s is %san IP address%s\n", search, ipmatch ? "" : "NOT ", ipmatch ? va( " with mask %d", mask ) : "" ); if( !ipmatch ) G_SanitiseString( search, s2, sizeof( s2 ) ); } ADMBP_begin(); for( n = g_admin_namelogs; n; n = n->next ) { - if( search[ 0 ] ) + if( ipmatch ) { - if( ipmatch ) + for( i = 0; i < MAX_ADMIN_NAMELOG_ADDRS && n->ip[ i ][ 0 ]; i++ ) { - if( !G_AddressParse( n->ip, &b, NULL ) || - !G_AddressCompare( &a, &b, mask ) ) - continue; + if( G_AddressParse( n->ip[ i ], &b, NULL ) && + G_AddressCompare( &a, &b, mask ) ) + break; } - else + if( i == MAX_ADMIN_NAMELOG_ADDRS || !n->ip[ i ][ 0 ] ) + continue; + } + else if( search[ 0 ] ) + { + for( i = 0; i < MAX_ADMIN_NAMELOG_NAMES && n->name[ i ][ 0 ]; i++ ) { - for( j = 0; j < MAX_ADMIN_NAMELOG_NAMES && n->name[ j ][ 0 ]; j++ ) - { - G_SanitiseString( n->name[ j ], n2, sizeof( n2 ) ); - if( strstr( n2, s2 ) ) - break; - } - if( j == MAX_ADMIN_NAMELOG_NAMES || !n->name[ j ][ 0 ] ) - continue; + G_SanitiseString( n->name[ i ], n2, sizeof( n2 ) ); + if( strstr( n2, s2 ) ) + break; } + if( i == MAX_ADMIN_NAMELOG_NAMES || !n->name[ i ][ 0 ] ) + continue; } printed++; - ADMBP( va( "%s (*%s) %15s^7", - ( n->slot > -1 ) ? va( "^3%-2d", n->slot ) : "- ", - n->guid + 24, n->ip ) ); - for( j = 0; j < MAX_ADMIN_NAMELOG_NAMES && n->name[ j ][ 0 ]; j++ ) - { - ADMBP( va( " '%s^7'", n->name[ j ] ) ); - } + ADMBP( va( "%s ^7", ( n->slot > -1 ) ? va( "^3%-2d", n->slot ) : "- " ) ); + for( i = 0; i < MAX_ADMIN_NAMELOG_ADDRS && n->ip[ i ][ 0 ]; i++ ) + ADMBP( va( " %s", n->ip[ i ] ) ); + for( i = 0; i < MAX_ADMIN_NAMELOG_NAMES && n->name[ i ][ 0 ]; i++ ) + ADMBP( va( " '%s^7'", n->name[ i ] ) ); ADMBP( "\n" ); } ADMBP( va( "^3!namelog:^7 %d recent clients found\n", printed ) ); diff --git a/src/game/g_admin.h b/src/game/g_admin.h index 6b2bf06b..49d60720 100644 --- a/src/game/g_admin.h +++ b/src/game/g_admin.h @@ -32,6 +32,7 @@ Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA #define ADMBP_end() G_admin_buffer_end(ent) #define MAX_ADMIN_NAMELOG_NAMES 5 +#define MAX_ADMIN_NAMELOG_ADDRS 5 #define MAX_ADMIN_FLAG_LEN 20 #define MAX_ADMIN_FLAGS 1024 #define MAX_ADMIN_CMD_LEN 20 @@ -128,8 +129,8 @@ g_admin_command_t; typedef struct g_admin_namelog { struct g_admin_namelog *next; - char name[ MAX_ADMIN_NAMELOG_NAMES ][MAX_NAME_LENGTH ]; - char ip[ 40 ]; + char name[ MAX_ADMIN_NAMELOG_NAMES ][ MAX_NAME_LENGTH ]; + char ip[ MAX_ADMIN_NAMELOG_ADDRS ][ 40 ]; char guid[ 33 ]; int slot; qboolean banned; -- cgit