/** * vim: set ts=4 : * =============================================================== * 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 /** * Provided by basecommands.sp when sm_ban is called. * * @param admin Admin client index (0 for server). * @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). * @return Pl_Handled to block output, Pl_Stop to block output and action. */ forward Action: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). * @return Pl_Handled to block output, Pl_Stop to block output and action. */ forward Action: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). * @return Pl_Handled to block output, Pl_Stop to block output and action. */ forward Action:OnBanRemoved(admin, const String:info[]); /** * 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. * * @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))) { strcopy(auth, sizeof(auth), "UNKNOWN"); } if (!GetClientName(client, name, sizeof(name))) { strcopy(name, sizeof(name), "UNKNOWN"); } /** Currently, no team stuff ... */ Format(buffer, maxlength, "\"%s<%d><%s><>\"", name, userid, auth); } /** * Returns plugin handle from plugin filename. * * @param filename Filename of the plugin to search for. * @return Handle to plugin if found, INVALID_HANDLE otherwise. */ 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)); if (strcmp(buffer, filename, false) == 0) { CloseHandle(iter); return pl; } } CloseHandle(iter); return INVALID_HANDLE; } /** * Searches for clients that match an input string. * * Allowed patterns: * 1) # or # * 2) * * @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. */ 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)); if (strcmp(name, pattern, false) == 0) { 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; } /** * 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]; }