sourcemod/plugins/admin-flatfile/admin-simple.sp

138 lines
3.2 KiB
SourcePawn
Raw Normal View History

/**
* admin-simple.sp
* Reads the admins.cfg file. Do not compile this directly.
* This file is part of SourceMod, Copyright (C) 2004-2007 AlliedModders LLC
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* 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, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* Version: $Id$
*/
public ReadSimpleUsers()
{
BuildPath(Path_SM, g_Filename, sizeof(g_Filename), "configs/admins_simple.ini");
new Handle:file = OpenFile(g_Filename, "rt");
if (file == INVALID_HANDLE)
{
ParseError("Could not open file!");
return;
}
while (!IsEndOfFile(file))
{
decl String:line[255];
if (!ReadFileLine(file, line, sizeof(line)))
{
break;
}
if ((line[0] == '/' && line[1] == '/')
|| (line[0] == ';' || line[0] == '\0'))
{
continue;
}
ReadAdminLine(line);
}
CloseHandle(file);
}
ReadAdminLine(const String:line[])
{
new String:auth[64];
new cur_idx = StrBreak(line, auth, sizeof(auth));
new idx = cur_idx;
if (cur_idx == -1)
{
/* This line is bad... we need at least two parameters */
return;
}
/* Create the admin */
new AdminId:admin = CreateAdmin(auth);
/* Read flags */
new String:flags[64];
cur_idx = StrBreak(line[idx], flags, sizeof(flags));
idx += cur_idx;
if (flags[0] == '@')
{
new GroupId:gid = FindAdmGroup(flags[1]);
if (gid == INVALID_GROUP_ID)
{
ParseError("Invalid group detected: %s", flags[1]);
return;
}
AdminInheritGroup(admin, gid);
} else {
new len = strlen(flags);
new bool:is_default = false;
for (new i=0; i<len; i++)
{
if (flags[i] < 'a' || flags[i] > 'z')
{
if (flags[i] == '$')
{
is_default = true;
} else {
ParseError("Invalid flag detected: %c", flags[i]);
}
continue;
}
new val = flags[i] - 'a';
if (!g_FlagsSet[val])
{
ParseError("Invalid flag detected: %c", flags[i]);
continue;
}
SetAdminFlag(admin, g_FlagLetters[val], true);
}
if (is_default)
{
new GroupId:gid = FindAdmGroup("Default");
if (gid != INVALID_GROUP_ID)
{
AdminInheritGroup(admin, gid);
}
}
}
/* Lastly, is there a password? */
if (cur_idx != -1)
{
decl String:password[64];
StrBreak(line[idx], password, sizeof(password));
SetAdminPassword(admin, password);
}
/* Now, bind the identity to something */
if (StrContains(auth, "STEAM_") == 0)
{
BindAdminIdentity(admin, AUTHMETHOD_STEAM, auth);
} else {
if (auth[0] == '!')
{
BindAdminIdentity(admin, AUTHMETHOD_IP, auth[1]);
} else {
BindAdminIdentity(admin, AUTHMETHOD_NAME, auth);
}
}
}