//exec("scripts/autoexec/TKwarn.cs"); package TKwarn { // From Evo function DefaultGame::testTeamKill(%game, %victimID, %killerID, %damageType) { if(!$countdownStarted && !$MatchStarted) return; %tk = Parent::testTeamKill(%game, %victimID, %killerID); if(!%tk) return false; // is not a tk // No Bots //if(%killerID.isAIcontrolled() || %victimID.isAIcontrolled()) //return true; // Log TeamKill teamkillLog(%victimID, %killerID, %damageType); //No warnings in tournament mode if($Host::TournamentMode) return true; // No Admins if(%killerID.isAdmin) return true; // Ignore this map if($CurrentMission $= "Mac_FlagArena" || $CurrentMission $= "Machineeggs") return true; // warn the player of the imminent kick vote if((%killerID.teamkills == $Host::TKWarn1 - 1) && $Host::TKWarn1 != 0) centerprint(%killerID, "You are receiving this warning for inappropriate teamkilling.\nBehave or a vote to kick will be started.", 10, 2); // warn the player of his imminent kick else if((%killerID.teamkills == $Host::TKWarn2 - 1) && $Host::TKWarn2 != 0) { TKvote("VoteKickPlayer", %killerID); centerprint(%killerID, "You are receiving this second warning for inappropriate teamkilling.\nBehave or you will be kicked.", 10, 2); } // kick the player else if((%killerID.teamkills >= $Host::TKMax - 1) && $Host::TKMax != 0) { Game.kickClientName = %killerID.name; TKkick(%killerID, true, %killerID.guid); adminLog( %killerID, " was autokicked for teamkilling." ); } return true; } }; // Prevent package from being activated if it is already if (!isActivePackage(TKwarn)) activatePackage(TKwarn); // we pass the guid as well, in case this guy leaves the server. function TKkick( %client, %admin, %guid ) { messageAll( 'MsgAdminForce', '\c2%1 has been autokicked for teamkilling.', %client.name ); // z0dd - ZOD, 7/13/03. Tell who kicked messageClient(%client, 'onClientKicked', ""); messageAllExcept( %client, -1, 'MsgClientDrop', "", Game.kickClientName, %client ); if( %client.isAIControlled() ) { if($Host::ClassicCanKickBots || %admin.isAdmin) { if(!$Host::ClassicBalancedBots) { $HostGameBotCount--; %client.drop(); } } } else { if( $playingOnline ) // won games { %count = ClientGroup.getCount(); %found = false; for( %i = 0; %i < %count; %i++ ) // see if this guy is still here... { %cl = ClientGroup.getObject( %i ); if( %cl.guid == %guid ) { %found = true; // kill and delete this client, their done in this server. if( isObject( %cl.player ) ) %cl.player.scriptKill(0); if ( isObject( %cl ) ) { %client.setDisconnectReason( "You have been kicked out of the game for teamkilling." ); // z0dd - ZOD, 7/13/03. Tell who kicked %cl.schedule(700, "delete"); } // ban by IP as well BanList::add( %guid, %client.getAddress(), $Host::KickBanTime ); } } if( !%found ) BanList::add( %guid, "0", $Host::KickBanTime ); // keep this guy out for a while since he left. } else // lan games { // kill and delete this client if( isObject( %client.player ) ) %client.player.scriptKill(0); if ( isObject( %client ) ) { %client.setDisconnectReason( "You have been kicked out of the game for teamkilling." ); %client.schedule(700, "delete"); } BanList::add( 0, %client.getAddress(), $Host::KickBanTime ); } } } // From Evo // Info: Auto start a new vote function TKvote(%typeName, %arg1, %arg2, %arg3, %arg4) { // works only for kicking players if(%typeName !$= "VoteKickPlayer") return; // only works for FFA mode if($Host::TournamentMode) return; // admins can't be kicked if(%arg1.isAdmin) return; //Stop current votes if(Game.scheduleVote !$= "") { //Added for vote overtime //Dont stop if under 90 secs left %curTimeLeftMS = ($Host::TimeLimit * 60 * 1000) + $missionStartTime - getSimTime(); if(%curTimeLeftMS <= 90000) { //log it $tkvoteLog = formatTimeString("M-d") SPC formatTimeString("[hh:nn:a]") SPC "[Autovote Cancelled]" SPC %arg1.nameBase @ "(" @ %arg1.guid @ ")" SPC "Teamkill Autovote cancelled due insufficient time. #P[" @ $HostGamePlayerCount @ "]" SPC "CM[" @ $CurrentMission @ "]"; if($Host::ClassicTeamKillLog) { %logpath = $Host::ClassicTeamKillLogPath; export("$tkvoteLog", %logpath, true); logEcho($tkvoteLog); } echo($tkvoteLog); return; } else //Stop any current votes { //Notify clients the vote is being cancelled for(%i = 0; %i < %count; %i++) { %cl = ClientGroup.getObject(%i); if(%cl !$= %arg1) //dont notify the team killer messageClient(%cl, 'VoteStarted', '\c2Vote has been cancelled due to teamkill autovote.'); } stopCurrentVote(); } } //notify any admins on the other team for(%i = 0; %i < ClientGroup.getCount(); %i++) { %cl = ClientGroup.getObject(%i); if (%cl.isAdmin == true) { if(%cl.team !$= %arg1.team) //Not on admins team messageClient(%cl, '', '\c5[A]\c1%1 \c0Teamkill Autovote started to kick %2 on the other team.~wgui/objective_notification.wav', "Vote in Progress:", %arg1.nameBase); } } echo(formatTimeString("M-d") SPC formatTimeString("[hh:nn:a]") SPC "Teamkill Autovote started for..." SPC %arg1.nameBase @ "(" @ %arg1.guid @ ")" SPC "#P[" @ $HostGamePlayerCount @ "]" SPC "CM[" @ $CurrentMission @ "]"); %clientsVoting = 0; Game.kickClient = %arg1; Game.kickClientName = %arg1.name; Game.kickGuid = %arg1.guid; Game.kickTeam = %arg1.team; %count = ClientGroup.getCount(); for(%i = 0; %i < %count; %i++) { %cl = ClientGroup.getObject(%i); if(%cl.team == %arg1.team && !%cl.isAIControlled() && %cl !$= %arg1) { messageClient(%cl, 'VoteStarted', '\c2Vote initiated to kick the teamkiller %1 with %2 teamkills.', %arg1.name, $Host::TKWarn2); %clientsVoting++; } } for(%i = 0; %i < %count; %i++) { %cl = ClientGroup.getObject(%i); if(%cl.team == %arg1.team && !%cl.isAIControlled() && %cl !$= %arg1) messageClient(%cl, 'openVoteHud', "", %clientsVoting, ($Host::VotePassPercent / 100)); } clearVotes(); Game.voteType = %typeName; Game.scheduleVote = schedule(($Host::VoteTime * 1000), 0, "calcVotes", %typeName, %arg1, %arg2, %arg3, %arg4); // Eolk - Voting control variables Game.votingArgs[typeName] = %typeName; Game.votingArgs[arg1] = %arg1; Game.votingArgs[arg2] = %arg2; Game.votingArgs[arg3] = %arg3; Game.votingArgs[arg4] = %arg4; // Log Vote voteLog(%client, %typeName, %arg1, %arg2, %arg3, "TeamkillAutovote"); }