mirror of
https://github.com/Jackzmc/sourcemod-plugins.git
synced 2025-05-07 04:43:21 +00:00
ftt: Prevent banning of admins
This commit is contained in:
parent
cbe60ecdfd
commit
af5dd5c6a6
2 changed files with 102 additions and 6 deletions
Binary file not shown.
|
@ -16,8 +16,6 @@
|
||||||
|
|
||||||
#undef REQUIRE_PLUGIN
|
#undef REQUIRE_PLUGIN
|
||||||
#include <adminmenu>
|
#include <adminmenu>
|
||||||
//TODO: Detect if player activates crescendo from far away
|
|
||||||
//Possibly cancel event, make poll for other users. if no one responds, activate troll mode/swarm or kick/ban depending on FF amount?
|
|
||||||
|
|
||||||
|
|
||||||
public Plugin myinfo =
|
public Plugin myinfo =
|
||||||
|
@ -59,6 +57,8 @@ public void OnPluginStart() {
|
||||||
LoadTranslations("common.phrases");
|
LoadTranslations("common.phrases");
|
||||||
g_iAmmoTable = FindSendPropInfo("CTerrorPlayer", "m_iAmmo");
|
g_iAmmoTable = FindSendPropInfo("CTerrorPlayer", "m_iAmmo");
|
||||||
|
|
||||||
|
g_PlayerMarkedForward = new GlobalForward("FTT_OnClientMarked", ET_Ignore, Param_Cell, Param_Cell);
|
||||||
|
|
||||||
hThrowItemInterval = CreateConVar("sm_ftt_throw_interval", "30", "The interval in seconds to throw items. 0 to disable", FCVAR_NONE, true, 0.0);
|
hThrowItemInterval = CreateConVar("sm_ftt_throw_interval", "30", "The interval in seconds to throw items. 0 to disable", FCVAR_NONE, true, 0.0);
|
||||||
hThrowItemInterval.AddChangeHook(Change_ThrowInterval);
|
hThrowItemInterval.AddChangeHook(Change_ThrowInterval);
|
||||||
hAutoPunish = CreateConVar("sm_ftt_autopunish_action", "0", "Setup automatic punishment of players. Add bits together\n0=Disabled, 1=Tank magnet, 2=Special magnet, 4=Swarm, 8=InstantVomit", FCVAR_NONE, true, 0.0);
|
hAutoPunish = CreateConVar("sm_ftt_autopunish_action", "0", "Setup automatic punishment of players. Add bits together\n0=Disabled, 1=Tank magnet, 2=Special magnet, 4=Swarm, 8=InstantVomit", FCVAR_NONE, true, 0.0);
|
||||||
|
@ -71,6 +71,8 @@ public void OnPluginStart() {
|
||||||
RegAdminCmd("sm_ftm", Command_ListModes, ADMFLAG_KICK, "Lists all the troll modes and their description");
|
RegAdminCmd("sm_ftm", Command_ListModes, ADMFLAG_KICK, "Lists all the troll modes and their description");
|
||||||
RegAdminCmd("sm_ftr", Command_ResetUser, ADMFLAG_KICK, "Resets user of any troll effects.");
|
RegAdminCmd("sm_ftr", Command_ResetUser, ADMFLAG_KICK, "Resets user of any troll effects.");
|
||||||
RegAdminCmd("sm_fta", Command_ApplyUser, ADMFLAG_KICK, "Apply a troll mod to a player, or shows menu if no parameters.");
|
RegAdminCmd("sm_fta", Command_ApplyUser, ADMFLAG_KICK, "Apply a troll mod to a player, or shows menu if no parameters.");
|
||||||
|
RegAdminCmd("sm_ftt", Command_FeedTheTrollMenu, ADMFLAG_KICK, "Opens a list that shows all the commands");
|
||||||
|
RegAdminCmd("sm_mark", Command_MarkPendingTroll, ADMFLAG_KICK, "Marks a player as to be banned on disconnect");
|
||||||
RegAdminCmd("sm_ftc", Command_FeedTheCrescendoTroll, ADMFLAG_KICK, "Applies a manual punish on the last crescendo activator");
|
RegAdminCmd("sm_ftc", Command_FeedTheCrescendoTroll, ADMFLAG_KICK, "Applies a manual punish on the last crescendo activator");
|
||||||
|
|
||||||
HookEvent("player_disconnect", Event_PlayerDisconnect);
|
HookEvent("player_disconnect", Event_PlayerDisconnect);
|
||||||
|
@ -103,8 +105,17 @@ public void OnMapStart() {
|
||||||
PrecacheSound("player/footsteps/clown/concrete1.wav");
|
PrecacheSound("player/footsteps/clown/concrete1.wav");
|
||||||
//CreateTimer(30.0, Timer_AutoPunishCheck, _, TIMER_REPEAT | TIMER_FLAG_NO_MAPCHANGE);
|
//CreateTimer(30.0, Timer_AutoPunishCheck, _, TIMER_REPEAT | TIMER_FLAG_NO_MAPCHANGE);
|
||||||
}
|
}
|
||||||
|
public void OnClientPutInServer(int client) {
|
||||||
|
g_PendingBanTroll[client] = false;
|
||||||
|
SDKHook(client, SDKHook_OnTakeDamage, Event_TakeDamage);
|
||||||
|
}
|
||||||
public void Event_PlayerDisconnect(Event event, const char[] name, bool dontBroadcast) {
|
public void Event_PlayerDisconnect(Event event, const char[] name, bool dontBroadcast) {
|
||||||
int client = GetClientOfUserId(event.GetInt("userid"));
|
int client = GetClientOfUserId(event.GetInt("userid"));
|
||||||
|
if(g_PendingBanTroll[client]) {
|
||||||
|
g_PendingBanTroll[client] = false;
|
||||||
|
if(!IsFakeClient(client) && GetUserAdmin(client) == INVALID_ADMIN_ID)
|
||||||
|
BanClient(client, 0, BANFLAG_AUTO, "TrollMarked", "Banned", "ftt", 0);
|
||||||
|
}
|
||||||
g_iTrollUsers[client] = 0;
|
g_iTrollUsers[client] = 0;
|
||||||
g_iAttackerTarget[client] = 0;
|
g_iAttackerTarget[client] = 0;
|
||||||
}
|
}
|
||||||
|
@ -142,6 +153,8 @@ public void Event_CarAlarm(Event event, const char[] name, bool dontBroadcast) {
|
||||||
//Ignore car alarms for autopunish
|
//Ignore car alarms for autopunish
|
||||||
lastButtonUser = -1;
|
lastButtonUser = -1;
|
||||||
}
|
}
|
||||||
|
//TODO: Add cvar to turn on/off targetting incapped
|
||||||
|
//TODO: Auto Special Maagnet on Anti-rush
|
||||||
public Action L4D2_OnChooseVictim(int attacker, int &curTarget) {
|
public Action L4D2_OnChooseVictim(int attacker, int &curTarget) {
|
||||||
// =========================
|
// =========================
|
||||||
// OVERRIDE VICTIM
|
// OVERRIDE VICTIM
|
||||||
|
@ -322,10 +335,20 @@ public Action OnPlayerRunCmd(int client, int& buttons, int& impulse, float vel[3
|
||||||
}
|
}
|
||||||
return Plugin_Continue;
|
return Plugin_Continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Action Event_TakeDamage(int victim, int& attacker, int& inflictor, float& damage, int& damagetype) {
|
public Action Event_TakeDamage(int victim, int& attacker, int& inflictor, float& damage, int& damagetype) {
|
||||||
if(attacker > 0 && attacker <= MaxClients && IsClientInGame(attacker) && IsPlayerAlive(attacker) && HasTrollMode(attacker, Troll_DamageBoost)) {
|
//Stop FF from marked:
|
||||||
damage * 2;
|
if(attacker > 0 && attacker <= MaxClients && IsClientInGame(attacker) && IsPlayerAlive(attacker)) {
|
||||||
|
if(g_PendingBanTroll[attacker] && GetClientTeam(attacker) == 2 && GetClientTeam(victim) == 2) {
|
||||||
|
|
||||||
|
return Plugin_Stop;
|
||||||
|
}
|
||||||
|
if(HasTrollMode(attacker, Troll_DamageBoost)) {
|
||||||
|
damage * 2;
|
||||||
|
return Plugin_Changed;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return Plugin_Continue;
|
||||||
}
|
}
|
||||||
public Action SoundHook(int[] clients, int& numClients, char sample[PLATFORM_MAX_PATH], int& entity, int& channel, float& volume, int& level, int& pitch, int& flags, char[] soundEntry, int& seed) {
|
public Action SoundHook(int[] clients, int& numClients, char sample[PLATFORM_MAX_PATH], int& entity, int& channel, float& volume, int& level, int& pitch, int& flags, char[] soundEntry, int& seed) {
|
||||||
if(lastButtonUser > -1 && StrEqual(sample, "npc/mega_mob/mega_mob_incoming.wav")) {
|
if(lastButtonUser > -1 && StrEqual(sample, "npc/mega_mob/mega_mob_incoming.wav")) {
|
||||||
|
@ -337,7 +360,7 @@ public Action SoundHook(int[] clients, int& numClients, char sample[PLATFORM_MAX
|
||||||
lastCrescendoUser = lastButtonUser;
|
lastCrescendoUser = lastButtonUser;
|
||||||
if(IsPlayerFarDistance(lastButtonUser, AUTOPUNISH_FLOW_MIN_DISTANCE)) {
|
if(IsPlayerFarDistance(lastButtonUser, AUTOPUNISH_FLOW_MIN_DISTANCE)) {
|
||||||
NotifyAllAdmins("Autopunishing player %N for activation of event far from team", lastButtonUser);
|
NotifyAllAdmins("Autopunishing player %N for activation of event far from team", lastButtonUser);
|
||||||
LogAction(0, "activated autopunish for crescendo activator %N (auto)", lastButtonUser);
|
ShowActivity(0, "activated autopunish for crescendo activator %N (auto)", lastButtonUser);
|
||||||
ActivateAutoPunish(lastButtonUser);
|
ActivateAutoPunish(lastButtonUser);
|
||||||
}
|
}
|
||||||
lastButtonUser = -1;
|
lastButtonUser = -1;
|
||||||
|
@ -476,7 +499,7 @@ public Action Command_ListModes(int client, int args) {
|
||||||
public Action Command_ListTheTrolls(int client, int args) {
|
public Action Command_ListTheTrolls(int client, int args) {
|
||||||
int count = 0;
|
int count = 0;
|
||||||
for(int i = 1; i < MaxClients; i++) {
|
for(int i = 1; i < MaxClients; i++) {
|
||||||
if(IsClientConnected(i) && IsPlayerAlive(i) && g_iTrollUsers[i] > 0) {
|
if(IsClientConnected(i) && IsClientInGame(i) && IsPlayerAlive(i) && g_iTrollUsers[i] > 0) {
|
||||||
int modes = g_iTrollUsers[i], modeCount = 0;
|
int modes = g_iTrollUsers[i], modeCount = 0;
|
||||||
char modeListArr[TROLL_MODE_COUNT][32];
|
char modeListArr[TROLL_MODE_COUNT][32];
|
||||||
for(int mode = 1; mode < TROLL_MODE_COUNT; mode++) {
|
for(int mode = 1; mode < TROLL_MODE_COUNT; mode++) {
|
||||||
|
@ -498,10 +521,79 @@ public Action Command_ListTheTrolls(int client, int args) {
|
||||||
return Plugin_Handled;
|
return Plugin_Handled;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Action Command_MarkPendingTroll(int client, int args) {
|
||||||
|
if(args == 0) {
|
||||||
|
Menu menu = new Menu(ChooseMarkedTroll);
|
||||||
|
menu.SetTitle("Choose a troll to mark");
|
||||||
|
char userid[8], display[16];
|
||||||
|
for(int i = 1; i < MaxClients; i++) {
|
||||||
|
if(IsClientConnected(i) && IsClientInGame(i) && IsPlayerAlive(i) && GetClientTeam(i) == 2) {
|
||||||
|
AdminId admin = GetUserAdmin(i);
|
||||||
|
if(admin == INVALID_ADMIN_ID) {
|
||||||
|
Format(userid, sizeof(userid), "%d", GetClientUserId(i));
|
||||||
|
GetClientName(i, display, sizeof(display));
|
||||||
|
menu.AddItem(userid, display);
|
||||||
|
}else{
|
||||||
|
ReplyToCommand(client, "%N is an admin cannot be marked.", i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
menu.ExitButton = true;
|
||||||
|
menu.Display(client, 0);
|
||||||
|
} else {
|
||||||
|
char arg1[32];
|
||||||
|
GetCmdArg(1, arg1, sizeof(arg1));
|
||||||
|
char target_name[MAX_TARGET_LENGTH];
|
||||||
|
int target_list[MAXPLAYERS], target_count;
|
||||||
|
bool tn_is_ml;
|
||||||
|
if ((target_count = ProcessTargetString(
|
||||||
|
arg1,
|
||||||
|
client,
|
||||||
|
target_list,
|
||||||
|
1,
|
||||||
|
COMMAND_FILTER_ALIVE, /* Only allow alive players */
|
||||||
|
target_name,
|
||||||
|
sizeof(target_name),
|
||||||
|
tn_is_ml)) <= 0
|
||||||
|
) {
|
||||||
|
/* This function replies to the admin with a failure message */
|
||||||
|
ReplyToTargetError(client, target_count);
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
|
int target = target_list[0];
|
||||||
|
if(IsClientConnected(target) && IsClientInGame(target) && GetClientTeam(target) == 2) {
|
||||||
|
ToggleMarkPlayer(client, target);
|
||||||
|
}else{
|
||||||
|
ReplyToCommand(client, "Player does not exist or is not a survivor.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Action Command_FeedTheTrollMenu(int client, int args) {
|
||||||
|
ReplyToCommand(client, "sm_ftl - Lists all the active trolls on players");
|
||||||
|
ReplyToCommand(client, "sm_ftm - Lists all available troll modes & descriptions");
|
||||||
|
ReplyToCommand(client, "sm_ftr - Resets target users' of their trolls");
|
||||||
|
ReplyToCommand(client, "sm_fta - Applies a troll mode on targets");
|
||||||
|
ReplyToCommand(client, "sm_ftt - Opens this menu");
|
||||||
|
ReplyToCommand(client, "sm_ftc - Will apply a punishment to last crescendo activator");
|
||||||
|
ReplyToCommand(client, "sm_mark - Marks the user to be banned on disconnect, prevents their FF.");
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
// MENU HANDLER
|
// MENU HANDLER
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
public int ChooseMarkedTroll(Menu menu, MenuAction action, int activator, int param2) {
|
||||||
|
if (action == MenuAction_Select) {
|
||||||
|
char info[16];
|
||||||
|
menu.GetItem(param2, info, sizeof(info));
|
||||||
|
int target = GetClientOfUserId(StringToInt(info));
|
||||||
|
ToggleMarkPlayer(activator, target);
|
||||||
|
} else if (action == MenuAction_End)
|
||||||
|
delete menu;
|
||||||
|
}
|
||||||
|
|
||||||
public int ChoosePlayerHandler(Menu menu, MenuAction action, int param1, int param2) {
|
public int ChoosePlayerHandler(Menu menu, MenuAction action, int param1, int param2) {
|
||||||
/* If an option was selected, tell the client about the item. */
|
/* If an option was selected, tell the client about the item. */
|
||||||
if (action == MenuAction_Select) {
|
if (action == MenuAction_Select) {
|
||||||
|
@ -663,6 +755,10 @@ public Action Timer_ResetAutoPunish(Handle timer, int user) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// /////////////////////////////////////////////////////////////////////////////
|
||||||
|
// NATIVES & FORWARDS
|
||||||
|
// /////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
// METHODS
|
// METHODS
|
||||||
///////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue