2007-02-09 05:41:03 +01:00
|
|
|
/**
|
2007-02-12 10:00:55 +01:00
|
|
|
* vim: set ts=4 :
|
2007-02-09 05:41:03 +01:00
|
|
|
* ===============================================================
|
|
|
|
* SourceMod (C)2004-2007 AlliedModders LLC. All rights reserved.
|
|
|
|
* ===============================================================
|
|
|
|
*
|
|
|
|
* This file is part of the SourceMod/SourcePawn SDK. This file may only be used
|
|
|
|
* or modified under the Terms and Conditions of its License Agreement, which is found
|
|
|
|
* in LICENSE.txt. The Terms and Conditions for making SourceMod extensions/plugins
|
|
|
|
* may change at any time. To view the latest information, see:
|
|
|
|
* http://www.sourcemod.net/license.php
|
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if defined _helpers_included
|
|
|
|
#endinput
|
|
|
|
#endif
|
|
|
|
#define _helpers_included
|
|
|
|
|
2007-06-08 06:40:40 +02:00
|
|
|
/**
|
|
|
|
* Provided by basecommands.sp when sm_ban is called.
|
|
|
|
*
|
2007-06-08 07:11:49 +02:00
|
|
|
* @param admin Admin client index (0 for server).
|
2007-06-08 06:40:40 +02:00
|
|
|
* @param client Client index which will be banned.
|
2007-06-08 07:11:49 +02:00
|
|
|
* @param time Minutes banned for (0 is permanent).
|
2007-06-08 06:40:40 +02:00
|
|
|
* @param reason Ban reason (may be empty if none exists).
|
2007-06-18 19:20:12 +02:00
|
|
|
* @return Pl_Handled to block output, Pl_Stop to block output and action.
|
2007-06-08 06:40:40 +02:00
|
|
|
*/
|
2007-06-18 19:20:12 +02:00
|
|
|
forward Action:OnClientBanned(admin, client, time, const String:reason[]);
|
2007-06-08 07:11:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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).
|
2007-06-18 19:20:12 +02:00
|
|
|
* @return Pl_Handled to block output, Pl_Stop to block output and action.
|
2007-06-08 07:11:49 +02:00
|
|
|
*/
|
2007-06-18 19:20:12 +02:00
|
|
|
forward Action:OnBanAdded(admin, const String:info[], time, const String:reason[]);
|
2007-06-08 07:11:49 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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).
|
2007-06-18 19:20:12 +02:00
|
|
|
* @return Pl_Handled to block output, Pl_Stop to block output and action.
|
2007-06-08 07:11:49 +02:00
|
|
|
*/
|
2007-06-18 19:20:12 +02:00
|
|
|
forward Action:OnBanRemoved(admin, const String:info[]);
|
2007-06-08 06:40:40 +02:00
|
|
|
|
2007-02-09 05:41:03 +01:00
|
|
|
/**
|
2007-06-18 19:20:12 +02:00
|
|
|
* Formats a user's info as log text. This is usually not needed because
|
|
|
|
* %L can be used to auto-format client information into a string.
|
2007-02-09 05:41:03 +01:00
|
|
|
*
|
|
|
|
* @param client Client index.
|
|
|
|
* @param buffer Buffer for text.
|
|
|
|
* @param maxlength Maximum length of text.
|
|
|
|
*/
|
|
|
|
stock FormatUserLogText(client, String:buffer[], maxlength)
|
|
|
|
{
|
|
|
|
decl String:auth[32];
|
|
|
|
decl String:name[40];
|
|
|
|
|
|
|
|
new userid = GetClientUserId(client);
|
|
|
|
if (!GetClientAuthString(client, auth, sizeof(auth)))
|
|
|
|
{
|
2007-07-09 08:19:57 +02:00
|
|
|
strcopy(auth, sizeof(auth), "UNKNOWN");
|
2007-02-09 05:41:03 +01:00
|
|
|
}
|
|
|
|
if (!GetClientName(client, name, sizeof(name)))
|
|
|
|
{
|
2007-07-09 08:19:57 +02:00
|
|
|
strcopy(name, sizeof(name), "UNKNOWN");
|
2007-02-09 05:41:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Currently, no team stuff ... */
|
|
|
|
|
|
|
|
Format(buffer, maxlength, "\"%s<%d><%s><>\"", name, userid, auth);
|
|
|
|
}
|
2007-03-16 07:54:24 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns plugin handle from plugin filename.
|
|
|
|
*
|
|
|
|
* @param filename Filename of the plugin to search for.
|
2007-03-16 07:57:31 +01:00
|
|
|
* @return Handle to plugin if found, INVALID_HANDLE otherwise.
|
2007-03-16 07:54:24 +01:00
|
|
|
*/
|
|
|
|
stock Handle:FindPluginByFile(const String:filename[])
|
|
|
|
{
|
|
|
|
decl String:buffer[256];
|
|
|
|
|
|
|
|
new Handle:iter = GetPluginIterator();
|
|
|
|
new Handle:pl;
|
|
|
|
|
|
|
|
while (MorePlugins(iter))
|
|
|
|
{
|
|
|
|
pl = ReadPlugin(iter);
|
|
|
|
|
|
|
|
GetPluginFilename(pl, buffer, sizeof(buffer));
|
2007-07-09 08:19:57 +02:00
|
|
|
if (strcmp(buffer, filename, false) == 0)
|
2007-03-16 07:54:24 +01:00
|
|
|
{
|
2007-06-18 19:20:12 +02:00
|
|
|
CloseHandle(iter);
|
2007-03-16 07:54:24 +01:00
|
|
|
return pl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-03-19 19:07:15 +01:00
|
|
|
CloseHandle(iter);
|
|
|
|
|
2007-03-16 07:54:24 +01:00
|
|
|
return INVALID_HANDLE;
|
|
|
|
}
|
2007-06-07 05:45:44 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Searches for clients that match an input string.
|
|
|
|
*
|
|
|
|
* Allowed patterns:
|
|
|
|
* 1) #<userid> or #<exact name>
|
|
|
|
* 2) <partial or full name>
|
2007-06-07 05:57:10 +02:00
|
|
|
*
|
|
|
|
* @param pattern Pattern to search for.
|
|
|
|
* @param clients Array to store matching clients in.
|
|
|
|
* @param maxClients Maximum clients in the array.
|
|
|
|
* @return Number of clients found.
|
2007-06-07 05:45:44 +02:00
|
|
|
*/
|
|
|
|
stock SearchForClients(const String:pattern[], clients[], maxClients)
|
|
|
|
{
|
|
|
|
new maxclients = GetMaxClients();
|
|
|
|
new total = 0;
|
|
|
|
|
|
|
|
if (maxClients == 0)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pattern[0] == '#')
|
|
|
|
{
|
|
|
|
new input = StringToInt(pattern[1]);
|
|
|
|
if (!input)
|
|
|
|
{
|
|
|
|
decl String:name[65]
|
|
|
|
for (new i=1; i<=maxclients; i++)
|
|
|
|
{
|
|
|
|
if (!IsClientInGame(i))
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
GetClientName(i, name, sizeof(name));
|
2007-07-09 08:19:57 +02:00
|
|
|
if (strcmp(name, pattern, false) == 0)
|
2007-06-07 05:45:44 +02:00
|
|
|
{
|
|
|
|
clients[0] = i;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
new client = GetClientOfUserId(input);
|
|
|
|
if (client)
|
|
|
|
{
|
|
|
|
clients[0] = client;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
decl String:name[65]
|
|
|
|
for (new i=1; i<=maxclients; i++)
|
|
|
|
{
|
|
|
|
if (!IsClientInGame(i))
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
GetClientName(i, name, sizeof(name));
|
|
|
|
if (StrContains(name, pattern, false) != -1)
|
|
|
|
{
|
|
|
|
clients[total++] = i;
|
|
|
|
if (total >= maxClients)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return total;
|
|
|
|
}
|
2007-07-27 01:31:58 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Wraps SearchForClients and handles producing error messages for
|
|
|
|
* bad targets.
|
|
|
|
*
|
|
|
|
* @param client Client who issued command
|
|
|
|
* @param target Client's target argument
|
|
|
|
* @param nobots Optional. Set to true if bots should NOT be targetted
|
|
|
|
* @param immunity Optional. Set to false to ignore target immunity.
|
|
|
|
* @return Index of target client, or -1 on error.
|
|
|
|
*/
|
|
|
|
stock FindTarget(client, const String:target[], bool:nobots = false, bool:immunity = true)
|
|
|
|
{
|
|
|
|
new clients[2];
|
|
|
|
new numClients = SearchForClients(target, clients, 2);
|
|
|
|
|
|
|
|
if (numClients == 0)
|
|
|
|
{
|
|
|
|
ReplyToCommand(client, "[SM] %t", "No matching client");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
else if (numClients > 1)
|
|
|
|
{
|
|
|
|
ReplyToCommand(client, "[SM] %t", "More than one client matches", target);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
else if (immunity && !CanUserTarget(client, clients[0]))
|
|
|
|
{
|
|
|
|
ReplyToCommand(client, "[SM] %t", "Unable to target");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
else if (nobots && IsFakeClient(clients[0]))
|
|
|
|
{
|
|
|
|
ReplyToCommand(client, "[SM] %t", "Cannot target bot");
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
return clients[0];
|
|
|
|
}
|