summaryrefslogtreecommitdiff
path: root/sourcemod-1.5-dev/scripting/include/admin.inc
diff options
context:
space:
mode:
Diffstat (limited to 'sourcemod-1.5-dev/scripting/include/admin.inc')
-rw-r--r--sourcemod-1.5-dev/scripting/include/admin.inc631
1 files changed, 631 insertions, 0 deletions
diff --git a/sourcemod-1.5-dev/scripting/include/admin.inc b/sourcemod-1.5-dev/scripting/include/admin.inc
new file mode 100644
index 0000000..40c5907
--- /dev/null
+++ b/sourcemod-1.5-dev/scripting/include/admin.inc
@@ -0,0 +1,631 @@
+/**
+ * vim: set ts=4 :
+ * =============================================================================
+ * SourceMod (C)2004-2008 AlliedModders LLC. All rights reserved.
+ * =============================================================================
+ *
+ * This file is part of the SourceMod/SourcePawn SDK.
+ *
+ * This program is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU General Public License, version 3.0, as published by the
+ * Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
+ * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
+ * details.
+ *
+ * You should have received a copy of the GNU General Public License along with
+ * this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * As a special exception, AlliedModders LLC gives you permission to link the
+ * code of this program (as well as its derivative works) to "Half-Life 2," the
+ * "Source Engine," the "SourcePawn JIT," and any Game MODs that run on software
+ * by the Valve Corporation. You must obey the GNU General Public License in
+ * all respects for all other code used. Additionally, AlliedModders LLC grants
+ * this exception to all derivative works. AlliedModders LLC defines further
+ * exceptions, found in LICENSE.txt (as of this writing, version JULY-31-2007),
+ * or <http://www.sourcemod.net/license.php>.
+ *
+ * Version: $Id$
+ */
+
+#if defined _admin_included
+ #endinput
+#endif
+#define _admin_included
+
+/**
+ * Access levels (flags) for admins.
+ */
+enum AdminFlag
+{
+ Admin_Reservation = 0, /**< Reserved slot */
+ Admin_Generic, /**< Generic admin abilities */
+ Admin_Kick, /**< Kick another user */
+ Admin_Ban, /**< Ban another user */
+ Admin_Unban, /**< Unban another user */
+ Admin_Slay, /**< Slay/kill/damage another user */
+ Admin_Changemap, /**< Change the map */
+ Admin_Convars, /**< Change basic convars */
+ Admin_Config, /**< Change configuration */
+ Admin_Chat, /**< Special chat privileges */
+ Admin_Vote, /**< Special vote privileges */
+ Admin_Password, /**< Set a server password */
+ Admin_RCON, /**< Use RCON */
+ Admin_Cheats, /**< Change sv_cheats and use its commands */
+ Admin_Root, /**< All access by default */
+ Admin_Custom1, /**< First custom flag type */
+ Admin_Custom2, /**< Second custom flag type */
+ Admin_Custom3, /**< Third custom flag type */
+ Admin_Custom4, /**< Fourth custom flag type */
+ Admin_Custom5, /**< Fifth custom flag type */
+ Admin_Custom6, /**< Sixth custom flag type */
+ /* --- */
+};
+
+#define AdminFlags_TOTAL 21 /**< Total number of admin flags */
+
+/**
+ * @section Bitwise values definitions for admin flags.
+ */
+#define ADMFLAG_RESERVATION (1<<0) /**< Convenience macro for Admin_Reservation as a FlagBit */
+#define ADMFLAG_GENERIC (1<<1) /**< Convenience macro for Admin_Generic as a FlagBit */
+#define ADMFLAG_KICK (1<<2) /**< Convenience macro for Admin_Kick as a FlagBit */
+#define ADMFLAG_BAN (1<<3) /**< Convenience macro for Admin_Ban as a FlagBit */
+#define ADMFLAG_UNBAN (1<<4) /**< Convenience macro for Admin_Unban as a FlagBit */
+#define ADMFLAG_SLAY (1<<5) /**< Convenience macro for Admin_Slay as a FlagBit */
+#define ADMFLAG_CHANGEMAP (1<<6) /**< Convenience macro for Admin_Changemap as a FlagBit */
+#define ADMFLAG_CONVARS (1<<7) /**< Convenience macro for Admin_Convars as a FlagBit */
+#define ADMFLAG_CONFIG (1<<8) /**< Convenience macro for Admin_Config as a FlagBit */
+#define ADMFLAG_CHAT (1<<9) /**< Convenience macro for Admin_Chat as a FlagBit */
+#define ADMFLAG_VOTE (1<<10) /**< Convenience macro for Admin_Vote as a FlagBit */
+#define ADMFLAG_PASSWORD (1<<11) /**< Convenience macro for Admin_Password as a FlagBit */
+#define ADMFLAG_RCON (1<<12) /**< Convenience macro for Admin_RCON as a FlagBit */
+#define ADMFLAG_CHEATS (1<<13) /**< Convenience macro for Admin_Cheats as a FlagBit */
+#define ADMFLAG_ROOT (1<<14) /**< Convenience macro for Admin_Root as a FlagBit */
+#define ADMFLAG_CUSTOM1 (1<<15) /**< Convenience macro for Admin_Custom1 as a FlagBit */
+#define ADMFLAG_CUSTOM2 (1<<16) /**< Convenience macro for Admin_Custom2 as a FlagBit */
+#define ADMFLAG_CUSTOM3 (1<<17) /**< Convenience macro for Admin_Custom3 as a FlagBit */
+#define ADMFLAG_CUSTOM4 (1<<18) /**< Convenience macro for Admin_Custom4 as a FlagBit */
+#define ADMFLAG_CUSTOM5 (1<<19) /**< Convenience macro for Admin_Custom5 as a FlagBit */
+#define ADMFLAG_CUSTOM6 (1<<20) /**< Convenience macro for Admin_Custom6 as a FlagBit */
+
+/**
+ * @endsection
+ */
+
+/**
+ * @section Hardcoded authentication methods
+ */
+#define AUTHMETHOD_STEAM "steam" /**< SteamID based authentication */
+#define AUTHMETHOD_IP "ip" /**< IP based authentication */
+#define AUTHMETHOD_NAME "name" /**< Name based authentication */
+
+/**
+ * @endsection
+ */
+
+/**
+ * Access override types.
+ */
+enum OverrideType
+{
+ Override_Command = 1, /**< Command */
+ Override_CommandGroup, /**< Command group */
+};
+
+/**
+ * Access override rules.
+ */
+enum OverrideRule
+{
+ Command_Deny = 0,
+ Command_Allow = 1,
+};
+
+/**
+ * DEPRECATED, do not use.
+ */
+enum ImmunityType
+{
+ Immunity_Default = 1, /**< Deprecated. */
+ Immunity_Global, /**< Deprecated. */
+};
+
+/**
+ * Identifies a unique entry in the group permissions cache. These are not Handles.
+ */
+enum GroupId
+{
+ INVALID_GROUP_ID = -1, /**< An invalid/non-existent group */
+};
+
+/**
+ * Identifies a unique entry in the admin permissions cache. These are not Handles.
+ */
+enum AdminId
+{
+ INVALID_ADMIN_ID = -1, /**< An invalid/non-existent admin */
+};
+
+/**
+ * Methods of computing access permissions.
+ */
+enum AdmAccessMode
+{
+ Access_Real, /**< Access the user has inherently */
+ Access_Effective, /**< Access the user has from their groups */
+};
+
+/**
+ * Represents the various cache regions.
+ */
+enum AdminCachePart
+{
+ AdminCache_Overrides = 0, /**< Global overrides */
+ AdminCache_Groups = 1, /**< All groups (automatically invalidates admins too) */
+ AdminCache_Admins = 2, /**< All admins */
+};
+
+/**
+ * Called when part of the cache needs to be rebuilt.
+ *
+ * @param part Part of the admin cache to rebuild.
+ */
+forward OnRebuildAdminCache(AdminCachePart:part);
+
+/**
+ * Tells the admin system to dump a portion of the cache.
+ *
+ * @param part Part of the cache to dump. Specifying groups also dumps admins.
+ * @param rebuild If true, the rebuild forwards will fire.
+ * @noreturn
+ */
+native DumpAdminCache(AdminCachePart:part, bool:rebuild);
+
+/**
+ * Adds a global command flag override. Any command registered with this name
+ * will assume the new flag. This is applied retroactively as well.
+ *
+ * @param cmd String containing command name (case sensitive).
+ * @param type Override type (specific command or group).
+ * @param flags New admin flag.
+ * @noreturn
+ */
+native AddCommandOverride(const String:cmd[], OverrideType:type, flags);
+
+/**
+ * Returns a command override.
+ *
+ * @param cmd String containing command name (case sensitive).
+ * @param type Override type (specific command or group).
+ * @param flags By-reference cell to store the flag (undefined if not found).
+ * @return True if there is an override, false otherwise.
+ */
+native bool:GetCommandOverride(const String:cmd[], OverrideType:type, &flags);
+
+/**
+ * Unsets a command override.
+ *
+ * @param cmd String containing command name (case sensitive).
+ * @param type Override type (specific command or group).
+ * @noreturn
+ */
+native UnsetCommandOverride(const String:cmd[], OverrideType:type);
+
+/**
+ * Adds a new group. Name must be unique.
+ *
+ * @param group_name String containing the group name.
+ * @return A new group id, INVALID_GROUP_ID if it already exists.
+ */
+native GroupId:CreateAdmGroup(const String:group_name[]);
+
+/**
+ * Finds a group by name.
+ *
+ * @param group_name String containing the group name.
+ * @return A group id, or INVALID_GROUP_ID if not found.
+ */
+native GroupId:FindAdmGroup(const String:group_name[]);
+
+/**
+ * Adds or removes a flag from a group's flag set.
+ * @note These are called "add flags" because they add to a user's flags.
+ *
+ * @param id Group id.
+ * @param flag Admin flag to toggle.
+ * @param enabled True to set the flag, false to unset/disable.
+ * @noreturn
+ */
+native SetAdmGroupAddFlag(GroupId:id, AdminFlag:flag, bool:enabled);
+
+/**
+ * Gets the set value of an add flag on a group's flag set.
+ * @note These are called "add flags" because they add to a user's flags.
+ *
+ * @param id Group id.
+ * @param flag Admin flag to retrieve.
+ * @return True if enabled, false otherwise,
+ */
+native bool:GetAdmGroupAddFlag(GroupId:id, AdminFlag:flag);
+
+/**
+ * Returns the flag set that is added to a user from their group.
+ * @note These are called "add flags" because they add to a user's flags.
+ *
+ * @param id GroupId of the group.
+ * @return Bitstring containing the flags enabled.
+ */
+native GetAdmGroupAddFlags(GroupId:id);
+
+/**
+ * @deprecated Functionality removed.
+ */
+#pragma deprecated Use SetAdmGroupImmunityLevel() instead.
+native SetAdmGroupImmunity(GroupId:id, ImmunityType:type, bool:enabled);
+
+/**
+ * @deprecated Functionality removed.
+ */
+#pragma deprecated Use GetAdmGroupImmunityLevel() instead.
+native bool:GetAdmGroupImmunity(GroupId:id, ImmunityType:type);
+
+/**
+ * Adds immunity to a specific group.
+ *
+ * @param id Group id.
+ * @param other_id Group id to receive immunity to.
+ * @noreturn
+ */
+native SetAdmGroupImmuneFrom(GroupId:id, GroupId:other_id);
+
+/**
+ * Returns the number of specific group immunities.
+ *
+ * @param id Group id.
+ * @return Number of group immunities.
+ */
+native GetAdmGroupImmuneCount(GroupId:id);
+
+/**
+ * Returns a group that this group is immune to given an index.
+ *
+ * @param id Group id.
+ * @param number Index from 0 to N-1, from GetAdmGroupImmuneCount().
+ * @return GroupId that this group is immune to, or INVALID_GROUP_ID on failure.
+ */
+native GroupId:GetAdmGroupImmuneFrom(GroupId:id, number);
+
+/**
+ * Adds a group-specific override type.
+ *
+ * @param id Group id.
+ * @param name String containing command name (case sensitive).
+ * @param type Override type (specific command or group).
+ * @param rule Override allow/deny setting.
+ * @noreturn
+ */
+native AddAdmGroupCmdOverride(GroupId:id, const String:name[], OverrideType:type, OverrideRule:rule);
+
+/**
+ * Retrieves a group-specific command override.
+ *
+ * @param id Group id.
+ * @param name String containing command name (case sensitive).
+ * @param type Override type (specific command or group).
+ * @param rule Optional pointer to store allow/deny setting.
+ * @return True if an override exists, false otherwise.
+ */
+native bool:GetAdmGroupCmdOverride(GroupId:id, const String:name[], OverrideType:type, &OverrideRule:rule);
+
+/**
+ * Registers an authentication identity type. You normally never need to call this except for
+ * very specific systems.
+ *
+ * @param name Codename to use for your authentication type.
+ * @noreturn
+ */
+native RegisterAuthIdentType(const String:name[]);
+
+/**
+ * Creates a new admin entry in the permissions cache.
+ *
+ * @param name Name for this entry (does not have to be unique).
+ * Specify an empty string for an anonymous admin.
+ */
+native AdminId:CreateAdmin(const String:name[]="");
+
+/**
+ * Retrieves an admin's user name as made with CreateAdmin().
+ *
+ * @note This function can return UTF-8 strings, and will safely chop UTF-8 strings.
+ *
+ * @param id AdminId of the admin.
+ * @param name String buffer to store name.
+ * @param maxlength Maximum size of string buffer.
+ * @return Number of bytes written.
+ */
+native GetAdminUsername(AdminId:id, String:name[], maxlength);
+
+/**
+ * Binds an admin to an identity for fast lookup later on. The bind must be unique.
+ *
+ * @param id AdminId of the admin.
+ * @param auth Auth method to use, predefined or from RegisterAuthIdentType().
+ * @param ident String containing the arbitrary, unique identity.
+ * @return True on success, false if the auth method was not found,
+ * or ident was already taken.
+ */
+native bool:BindAdminIdentity(AdminId:id, const String:auth[], const String:ident[]);
+
+/**
+ * Sets whether or not a flag is enabled on an admin.
+ *
+ * @param id AdminId index of the admin.
+ * @param flag Admin flag to use.
+ * @param enabled True to enable, false to disable.
+ * @noreturn
+ */
+native SetAdminFlag(AdminId:id, AdminFlag:flag, bool:enabled);
+
+/**
+ * Returns whether or not a flag is enabled on an admin.
+ *
+ * @param id AdminId index of the admin.
+ * @param flag Admin flag to use.
+ * @param mode Access mode to check.
+ * @return True if enabled, false otherwise.
+ */
+native bool:GetAdminFlag(AdminId:id, AdminFlag:flag, AdmAccessMode:mode=Access_Effective);
+
+/**
+ * Returns the bitstring of access flags on an admin.
+ *
+ * @param id AdminId index of the admin.
+ * @param mode Access mode to use.
+ * @return A bitstring containing which flags are enabled.
+ */
+native GetAdminFlags(AdminId:id, AdmAccessMode:mode);
+
+/**
+ * Adds a group to an admin's inherited group list. Any flags the group has
+ * will be added to the admin's effective flags.
+ *
+ * @param id AdminId index of the admin.
+ * @param gid GroupId index of the group.
+ * @return True on success, false on invalid input or duplicate membership.
+ */
+native bool:AdminInheritGroup(AdminId:id, GroupId:gid);
+
+/**
+ * Returns the number of groups this admin is a member of.
+ *
+ * @param id AdminId index of the admin.
+ * @return Number of groups this admin is a member of.
+ */
+native GetAdminGroupCount(AdminId:id);
+
+/**
+ * Returns group information from an admin.
+ *
+ * @param id AdminId index of the admin.
+ * @param index Group number to retrieve, from 0 to N-1, where N
+ * is the value of GetAdminGroupCount(id).
+ * @param name Buffer to store the group's name.
+ * Note: This will safely chop UTF-8 strings.
+ * @param maxlength Maximum size of the output name buffer.
+ * @return A GroupId index and a name pointer, or
+ * INVALID_GROUP_ID and NULL if an error occurred.
+*/
+native GroupId:GetAdminGroup(AdminId:id, index, const String:name[], maxlength);
+
+/**
+ * Sets a password on an admin.
+ *
+ * @param id AdminId index of the admin.
+ * @param password String containing the password.
+ * @noreturn
+ */
+native SetAdminPassword(AdminId:id, const String:password[]);
+
+/**
+ * Gets an admin's password.
+ *
+ * @param id AdminId index of the admin.
+ * @param buffer Optional buffer to store the admin's password.
+ * @param maxlength Maximum size of the output name buffer.
+ * Note: This will safely chop UTF-8 strings.
+ * @return True if there was a password set, false otherwise.
+ */
+native bool:GetAdminPassword(AdminId:id, String:buffer[]="", maxlength=0);
+
+/**
+ * Attempts to find an admin by an auth method and an identity.
+ *
+ * @param auth Auth method to try.
+ * @param identity Identity string to look up.
+ * @return An AdminId index if found, INVALID_ADMIN_ID otherwise.
+ */
+native AdminId:FindAdminByIdentity(const String:auth[], const String:identity[]);
+
+/**
+ * Removes an admin entry from the cache.
+ *
+ * @note This will remove any bindings to a specific user.
+ *
+ * @param id AdminId index to remove/invalidate.
+ * @return True on success, false otherwise.
+ */
+native bool:RemoveAdmin(AdminId:id);
+
+/**
+ * Converts a flag bit string to a bit array.
+ *
+ * @param bits Bit string containing the flags.
+ * @param array Array to write the flags to. Enabled flags will be 'true'.
+ * @param maxSize Maximum number of flags the array can store.
+ * @return Number of flags written.
+ */
+native FlagBitsToBitArray(bits, bool:array[], maxSize);
+
+/**
+ * Converts a flag array to a bit string.
+ *
+ * @param array Array containing true or false for each AdminFlag.
+ * @param maxSize Maximum size of the flag array.
+ * @return A bit string composed of the array bits.
+ */
+native FlagBitArrayToBits(const bool:array[], maxSize);
+
+/**
+ * Converts an array of flags to bits.
+ *
+ * @param array Array containing flags that are enabled.
+ * @param numFlags Number of flags in the array.
+ * @return A bit string composed of the array flags.
+ */
+native FlagArrayToBits(const AdminFlag:array[], numFlags);
+
+/**
+ * Converts a bit string to an array of flags.
+ *
+ * @param bits Bit string containing the flags.
+ * @param array Output array to write flags.
+ * @param maxSize Maximum size of the flag array.
+ * @return Number of flags written.
+ */
+native FlagBitsToArray(bits, AdminFlag:array[], maxSize);
+
+/**
+ * Finds a flag by its string name.
+ *
+ * @param name Flag name (like "kick"), case sensitive.
+ * @param flag Variable to store flag in.
+ * @return True on success, false if not found.
+ */
+native bool:FindFlagByName(const String:name[], &AdminFlag:flag);
+
+/**
+ * Finds a flag by a given character.
+ *
+ * @param c Flag ASCII character/token.
+ * @param flag Variable to store flag in.
+ * @return True on success, false if not found.
+ */
+native bool:FindFlagByChar(c, &AdminFlag:flag);
+
+/**
+ * Finds a flag char by a gived admin flag.
+ *
+ * @param flag Flag to look up.
+ * @param c Variable to store flag char.
+ * @return True on success, false if not found.
+ */
+native bool:FindFlagChar(AdminFlag:flag, &c);
+
+/**
+ * Converts a string of flag characters to a bit string.
+ *
+ * @param flags Flag ASCII string.
+ * @param numchars Optional variable to store the number of bytes read.
+ * @return Bit string of ADMFLAG values.
+ */
+native ReadFlagString(const String:flags[], &numchars=0);
+
+/**
+ * Tests whether one admin can target another.
+ *
+ * The heuristics for this check are as follows:
+ * 0. If the targeting AdminId is INVALID_ADMIN_ID, targeting fails.
+ * 1. If the targeted AdminId is INVALID_ADMIN_ID, targeting succeeds.
+ * 2. If the targeted AdminId is the same as the targeting AdminId,
+ * (self) targeting succeeds.
+ * 3. If the targeting admin is root, targeting succeeds.
+ * 4. If the targeted admin has access higher (as interpreted by
+ * (sm_immunity_mode) than the targeting admin, then targeting fails.
+ * 5. If the targeted admin has specific immunity from the
+ * targeting admin via group immunities, targeting fails.
+ * 6. Targeting succeeds.
+ *
+ * @param admin Admin doing the targetting (may be INVALID_ADMIN_ID).
+ * @param target Target admin (may be INVALID_ADMIN_ID).
+ * @return True if targetable, false if immune.
+ */
+native CanAdminTarget(AdminId:admin, AdminId:target);
+
+/**
+ * Creates an admin auth method. This does not need to be called more than once
+ * per method, ever.
+ *
+ * @param method Name of the authentication method.
+ * @return True on success, false on failure.
+ */
+native bool:CreateAuthMethod(const String:method[]);
+
+/**
+ * Sets a group's immunity level.
+ *
+ * @param gid Group Id.
+ * @param level Immunity level value.
+ * @return Old immunity level value.
+ */
+native SetAdmGroupImmunityLevel(GroupId:gid, level);
+
+/**
+ * Gets a group's immunity level (defaults to 0).
+ *
+ * @param gid Group Id.
+ * @return Immunity level value.
+ */
+native GetAdmGroupImmunityLevel(GroupId:gid);
+
+/**
+ * Sets an admin's immunity level.
+ *
+ * @param id Admin Id.
+ * @param level Immunity level value.
+ * @return Old immunity level value.
+ */
+native SetAdminImmunityLevel(AdminId:id, level);
+
+/**
+ * Gets an admin's immunity level.
+ *
+ * @param id Admin Id.
+ * @return Immunity level value.
+ */
+native GetAdminImmunityLevel(AdminId:id);
+
+/**
+ * Converts a flag to its single bit.
+ *
+ * @param flag Flag to convert.
+ * @return Bit representation of the flag.
+ */
+stock FlagToBit(AdminFlag:flag)
+{
+ return (1<<_:flag);
+}
+
+/**
+ * Converts a bit to an AdminFlag.
+ *
+ * @param bit Bit to convert.
+ * @param flag Stores the converted flag by reference.
+ * @return True on success, false otherwise.
+ */
+stock bool:BitToFlag(bit, &AdminFlag:flag)
+{
+ new AdminFlag:array[1];
+
+ if (FlagBitsToArray(bit, array, 1))
+ {
+ flag = array[0];
+ return true;
+ }
+
+ return false;
+}
+