- added amb1332, new cvar protection mechanism for rcon_password

- removed FCVAR_PROTECTED from Core cvars

--HG--
extra : convert_revision : svn%3A39bc706e-5318-0410-9160-8a85361fbb7c/trunk%401845
This commit is contained in:
David Anderson 2008-01-08 03:06:33 +00:00
parent 63592212d5
commit 42a313486a
4 changed files with 66 additions and 29 deletions

View File

@ -50,7 +50,7 @@ AdminCache g_Admins;
AdminFlag g_FlagLetters[26];
bool g_FlagSet[26];
ConVar sm_immunity_mode("sm_immunity_mode", "1", FCVAR_SPONLY|FCVAR_PROTECTED, "Mode for deciding immunity protection");
ConVar sm_immunity_mode("sm_immunity_mode", "1", FCVAR_SPONLY, "Mode for deciding immunity protection");
/* Default flags */
AdminFlag g_DefaultFlags[26] =

View File

@ -38,7 +38,7 @@
#include <inetchannel.h>
#include <iclient.h>
ConVar sm_show_activity("sm_show_activity", "13", FCVAR_SPONLY|FCVAR_PROTECTED, "Activity display setting (see sourcemod.cfg)");
ConVar sm_show_activity("sm_show_activity", "13", FCVAR_SPONLY, "Activity display setting (see sourcemod.cfg)");
static cell_t sm_GetClientCount(IPluginContext *pCtx, const cell_t *params)
{

View File

@ -49,6 +49,7 @@ public Plugin:myinfo =
new Handle:hTopMenu = INVALID_HANDLE;
new Handle:g_MapList;
new Handle:g_ProtectedVars;
#include "basecommands/kick.sp"
#include "basecommands/reloadadmins.sp"
@ -85,6 +86,11 @@ public OnPluginStart()
decl String:mapListPath[PLATFORM_MAX_PATH];
BuildPath(Path_SM, mapListPath, sizeof(mapListPath), "configs/adminmenu_maplist.ini");
SetMapListCompatBind("sm_map menu", mapListPath);
g_ProtectedVars = CreateTrie();
ProtectVar("rcon_password");
ProtectVar("sm_show_activity");
ProtectVar("sm_immunity_mode");
}
public OnMapStart()
@ -97,6 +103,17 @@ public OnConfigsExecuted()
LoadMapList(g_MapList);
}
ProtectVar(const String:cvar[])
{
SetTrieValue(g_ProtectedVars, cvar, 1);
}
bool:IsVarProtected(const String:cvar[])
{
decl dummy_value;
return GetTrieValue(g_ProtectedVars, cvar, dummy_value);
}
public OnAdminMenuReady(Handle:topmenu)
{
/* Block us from being called twice */
@ -244,13 +261,33 @@ public Action:Command_Cvar(client, args)
{
if (args < 1)
{
ReplyToCommand(client, "[SM] Usage: sm_cvar <cvar> [value]");
if (client == 0)
{
ReplyToCommand(client, "[SM] Usage: sm_cvar <cvar|protect> [value]");
}
else
{
ReplyToCommand(client, "[SM] Usage: sm_cvar <cvar> [value]");
}
return Plugin_Handled;
}
decl String:cvarname[64];
GetCmdArg(1, cvarname, sizeof(cvarname));
if (client == 0 && StrEqual(cvarname, "protect"))
{
if (args < 2)
{
ReplyToCommand(client, "[SM] Usage: sm_cvar <protect> <cvar>");
return Plugin_Handled;
}
GetCmdArg(2, cvarname, sizeof(cvarname));
ProtectVar(cvarname);
ReplyToCommand(client, "[SM] %t", "Cvar is now protected", cvarname);
return Plugin_Handled;
}
new Handle:hndl = FindConVar(cvarname);
if (hndl == INVALID_HANDLE)
{
@ -259,33 +296,27 @@ public Action:Command_Cvar(client, args)
}
new bool:allowed = false;
if (GetConVarFlags(hndl) & FCVAR_PROTECTED)
{
/* If they're root, allow anything */
if ((GetUserFlagBits(client) & ADMFLAG_ROOT) == ADMFLAG_ROOT)
{
allowed = true;
}
/* If they're not root, and getting sv_password, see if they have ADMFLAG_PASSWORD */
else if (StrEqual(cvarname, "sv_password") && (GetUserFlagBits(client) & ADMFLAG_PASSWORD))
{
allowed = true;
}
}
/* Do a check for the cheat cvar */
else if (StrEqual(cvarname, "sv_cheats"))
{
if (GetUserFlagBits(client) & ADMFLAG_CHEATS
|| GetUserFlagBits(client) & ADMFLAG_ROOT)
{
allowed = true;
}
}
/* If we drop down to here, it was a normal cvar. */
else
new client_flags = GetUserFlagBits(client);
if (client_flags & ADMFLAG_ROOT)
{
allowed = true;
}
else
{
if (GetConVarFlags(hndl) & FCVAR_PROTECTED)
{
allowed = ((client_flags & ADMFLAG_PASSWORD) == ADMFLAG_PASSWORD);
}
else if (StrEqual(cvarname, "sv_cheats"))
{
allowed = ((client_flags & ADMFLAG_CHEATS) == ADMFLAG_CHEATS);
}
else if (!IsVarProtected(cvarname))
{
allowed = true;
}
}
if (!allowed)
{

View File

@ -129,4 +129,10 @@
{
"en" "Admin access"
}
"Cvar is now protected"
{
"#format" "{1:s}"
"en" "Cvar {1} is now protected."
}
}