added another unban command and added forwards for banning (amb369)
--HG-- extra : convert_revision : svn%3A39bc706e-5318-0410-9160-8a85361fbb7c/trunk%40933
This commit is contained in:
parent
48830e2c16
commit
706b28cb64
@ -34,6 +34,8 @@ public Plugin:myinfo =
|
|||||||
};
|
};
|
||||||
|
|
||||||
new Handle:hBanForward = INVALID_HANDLE;
|
new Handle:hBanForward = INVALID_HANDLE;
|
||||||
|
new Handle:hAddBanForward = INVALID_HANDLE;
|
||||||
|
new Handle:hBanRemoved = INVALID_HANDLE;
|
||||||
|
|
||||||
public OnPluginStart()
|
public OnPluginStart()
|
||||||
{
|
{
|
||||||
@ -47,8 +49,84 @@ public OnPluginStart()
|
|||||||
RegAdminCmd("sm_who", Command_Who, ADMFLAG_GENERIC, "sm_who [#userid|name]");
|
RegAdminCmd("sm_who", Command_Who, ADMFLAG_GENERIC, "sm_who [#userid|name]");
|
||||||
RegAdminCmd("sm_ban", Command_Ban, ADMFLAG_BAN, "sm_ban <#userid|name> <minutes|0> [reason]");
|
RegAdminCmd("sm_ban", Command_Ban, ADMFLAG_BAN, "sm_ban <#userid|name> <minutes|0> [reason]");
|
||||||
RegAdminCmd("sm_unban", Command_Unban, ADMFLAG_UNBAN, "sm_unban <steamid>");
|
RegAdminCmd("sm_unban", Command_Unban, ADMFLAG_UNBAN, "sm_unban <steamid>");
|
||||||
|
RegAdminCmd("sm_addban", Command_AddBan, ADMFLAG_ROOT, "sm_addban <time> <steamid> [reason]");
|
||||||
|
RegAdminCmd("sm_banip", Command_BanIp, ADMFLAG_ROOT, "sm_banip <time> <ip> [reason]");
|
||||||
|
|
||||||
hBanForward = CreateGlobalForward("OnClientBanned", ET_Ignore, Param_Cell, Param_Cell, Param_String);
|
hBanForward = CreateGlobalForward("OnClientBanned", ET_Ignore, Param_Cell, Param_Cell, Param_Cell, Param_String);
|
||||||
|
hAddBanForward = CreateGlobalForward("OnBanAdded", ET_Ignore, Param_Cell, Param_String, Param_Cell, Param_String);
|
||||||
|
hBanRemoved = CreateGlobalForward("OnBanRemoved", ET_Ignore, Param_Cell, Param_String);
|
||||||
|
}
|
||||||
|
|
||||||
|
public Action:Command_BanIp(client, args)
|
||||||
|
{
|
||||||
|
if (args < 2)
|
||||||
|
{
|
||||||
|
ReplyToCommand(client, "[SM] Usage: sm_banip <time> <ip> [reason]");
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
|
|
||||||
|
new String:arg[50], String:time[20];
|
||||||
|
GetCmdArg(1, time, sizeof(time));
|
||||||
|
GetCmdArg(2, arg, sizeof(arg));
|
||||||
|
|
||||||
|
new minutes = StringToInt(time);
|
||||||
|
|
||||||
|
new String:reason[128];
|
||||||
|
if (args >= 3)
|
||||||
|
{
|
||||||
|
GetCmdArg(3, reason, sizeof(reason));
|
||||||
|
}
|
||||||
|
|
||||||
|
LogMessage("\"%L\" added ban (minutes \"%d\") (ip \"%s\") (reason \"%s\")", client, minutes, arg, reason);
|
||||||
|
|
||||||
|
Call_StartForward(hAddBanForward);
|
||||||
|
Call_PushCell(client);
|
||||||
|
Call_PushString(arg);
|
||||||
|
Call_PushCell(minutes);
|
||||||
|
Call_PushString(reason);
|
||||||
|
Call_Finish();
|
||||||
|
|
||||||
|
ServerCommand("banip %d %s", minutes, arg);
|
||||||
|
ServerCommand("writeip");
|
||||||
|
ReplyToCommand(client, "[SM] %t", "Ban added");
|
||||||
|
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Action:Command_AddBan(client, args)
|
||||||
|
{
|
||||||
|
if (args < 2)
|
||||||
|
{
|
||||||
|
ReplyToCommand(client, "[SM] Usage: sm_addban <time> <steamid> [reason]");
|
||||||
|
return Plugin_Handled;
|
||||||
|
}
|
||||||
|
|
||||||
|
new String:arg[50], String:time[20];
|
||||||
|
GetCmdArg(1, time, sizeof(time));
|
||||||
|
GetCmdArg(2, arg, sizeof(arg));
|
||||||
|
|
||||||
|
new minutes = StringToInt(time);
|
||||||
|
|
||||||
|
new String:reason[128];
|
||||||
|
if (args >= 3)
|
||||||
|
{
|
||||||
|
GetCmdArg(3, reason, sizeof(reason));
|
||||||
|
}
|
||||||
|
|
||||||
|
LogMessage("\"%L\" added ban (minutes \"%d\") (id \"%s\") (reason \"%s\")", client, minutes, arg, reason);
|
||||||
|
|
||||||
|
Call_StartForward(hAddBanForward);
|
||||||
|
Call_PushCell(client);
|
||||||
|
Call_PushString(arg);
|
||||||
|
Call_PushCell(minutes);
|
||||||
|
Call_PushString(reason);
|
||||||
|
Call_Finish();
|
||||||
|
|
||||||
|
ServerCommand("banid %d %s", minutes, arg);
|
||||||
|
ServerCommand("writeid");
|
||||||
|
ReplyToCommand(client, "[SM] %t", "Ban added");
|
||||||
|
|
||||||
|
return Plugin_Handled;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Action:Command_Unban(client, args)
|
public Action:Command_Unban(client, args)
|
||||||
@ -60,6 +138,7 @@ public Action:Command_Unban(client, args)
|
|||||||
}
|
}
|
||||||
|
|
||||||
new String:arg[50], start=0;
|
new String:arg[50], start=0;
|
||||||
|
new String:new_arg[50];
|
||||||
GetCmdArgString(arg, sizeof(arg));
|
GetCmdArgString(arg, sizeof(arg));
|
||||||
|
|
||||||
if (strncmp(arg, "STEAM_0:", 8) == 0)
|
if (strncmp(arg, "STEAM_0:", 8) == 0)
|
||||||
@ -71,7 +150,15 @@ public Action:Command_Unban(client, args)
|
|||||||
}
|
}
|
||||||
|
|
||||||
LogMessage("\"%L\" removed ban (filter \"%s\")", arg[start]);
|
LogMessage("\"%L\" removed ban (filter \"%s\")", arg[start]);
|
||||||
|
|
||||||
|
Format(new_arg, sizeof(new_arg), "STEAM_0:%s", arg[start]);
|
||||||
|
Call_StartForward(hBanRemoved);
|
||||||
|
Call_PushCell(client);
|
||||||
|
Call_PushString(new_arg);
|
||||||
|
Call_Finish();
|
||||||
|
|
||||||
ServerCommand("removeid \"%s\"", arg[start]);
|
ServerCommand("removeid \"%s\"", arg[start]);
|
||||||
|
ServerCommand("writeid");
|
||||||
ReplyToCommand(client, "[SM] %t", "Removed bans matching", arg);
|
ReplyToCommand(client, "[SM] %t", "Removed bans matching", arg);
|
||||||
|
|
||||||
return Plugin_Handled;
|
return Plugin_Handled;
|
||||||
@ -145,6 +232,7 @@ public Action:Command_Ban(client, args)
|
|||||||
Call_StartForward(hBanForward);
|
Call_StartForward(hBanForward);
|
||||||
Call_PushCell(client);
|
Call_PushCell(client);
|
||||||
Call_PushCell(clients[0]);
|
Call_PushCell(clients[0]);
|
||||||
|
Call_PushCell(time);
|
||||||
Call_PushString(reason);
|
Call_PushString(reason);
|
||||||
Call_Finish();
|
Call_Finish();
|
||||||
|
|
||||||
|
@ -21,11 +21,30 @@
|
|||||||
/**
|
/**
|
||||||
* Provided by basecommands.sp when sm_ban is called.
|
* Provided by basecommands.sp when sm_ban is called.
|
||||||
*
|
*
|
||||||
* @param admin Admin client index.
|
* @param admin Admin client index (0 for server).
|
||||||
* @param client Client index which will be banned.
|
* @param client Client index which will be banned.
|
||||||
|
* @param time Minutes banned for (0 is permanent).
|
||||||
* @param reason Ban reason (may be empty if none exists).
|
* @param reason Ban reason (may be empty if none exists).
|
||||||
*/
|
*/
|
||||||
forward OnClientBanned(admin, client, const String:reason[]);
|
forward OnClientBanned(admin, client, time, const String:reason[]);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provided by basecommands.sp when sm_addban or sm_banip is called.
|
||||||
|
*
|
||||||
|
* @param admin Admin client index (0 for server).
|
||||||
|
* @param info User info (either steamid or ip).
|
||||||
|
* @param time Minutes banned for (0 is permanent).
|
||||||
|
* @param reason Ban reason (may be empty if none exists).
|
||||||
|
*/
|
||||||
|
forward OnBanAdded(admin, const String:info[], time, const String:reason[]);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provided by basecommands.sp when sm_unban or sm_unbanip is called.
|
||||||
|
*
|
||||||
|
* @param admin Admin client index (0 for server).
|
||||||
|
* @param info User info (either steamid or ip).
|
||||||
|
*/
|
||||||
|
forward OnBanRemoved(admin, const String:info[]);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Formats a user's info as log text.
|
* Formats a user's info as log text.
|
||||||
|
@ -64,4 +64,9 @@
|
|||||||
"#format" "{1:s}"
|
"#format" "{1:s}"
|
||||||
"en" "Removed bans matching filter: {1}"
|
"en" "Removed bans matching filter: {1}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
"Ban added"
|
||||||
|
{
|
||||||
|
"en" "Ban has been added."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user