diff --git a/plugins/ns/admincmd.sma b/plugins/ns/admincmd.sma deleted file mode 100755 index d1e07809..00000000 --- a/plugins/ns/admincmd.sma +++ /dev/null @@ -1,693 +0,0 @@ -/* AMX Mod X -* Admin Commands Plugin -* -* by the AMX Mod X Development Team -* originally developed by OLO -* -* This file is part of AMX Mod X. -* -* -* 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -* -* In addition, as a special exception, the author gives permission to -* link the code of this program with the Half-Life Game Engine ("HL -* Engine") and Modified Game Libraries ("MODs") developed by Valve, -* L.L.C ("Valve"). You must obey the GNU General Public License in all -* respects for all of the code used other than the HL Engine and MODs -* from Valve. If you modify this file, you may extend this exception -* to your version of the file, but you are not obligated to do so. If -* you do not wish to do so, delete this exception statement from your -* version. -*/ - -#include -#include - -#define MAXRCONCVARS 16 -new g_cvarRcon[ MAXRCONCVARS ][32] -new g_cvarRconNum -new g_pauseCon -new Float:g_pausAble -new bool:g_Paused -new g_addCvar[] = "amx_cvar add %s" - -public plugin_init() { - register_plugin("Admin Commands",AMXX_VERSION_STR,"AMXX Dev Team") - register_dictionary("admincmd.txt") - register_dictionary("common.txt") - register_concmd("amx_kick","cmdKick",ADMIN_KICK," [reason]") - register_concmd("amx_ban","cmdBan",ADMIN_BAN," [reason]") - register_concmd("amx_banip","cmdBanIP",ADMIN_BAN," [reason]") - register_concmd("amx_addban","cmdAddBan",ADMIN_BAN," [reason]") - register_concmd("amx_unban","cmdUnban",ADMIN_BAN,"") - register_concmd("amx_slay","cmdSlay",ADMIN_SLAY,"") - register_concmd("amx_slap","cmdSlap",ADMIN_SLAY," [power]") - register_concmd("amx_leave","cmdLeave",ADMIN_KICK," [tag] [tag] [tag]") - register_concmd("amx_pause","cmdPause",ADMIN_CVAR,"- pause or unpause the game") - register_concmd("amx_who","cmdWho",ADMIN_ADMIN,"- displays who is on server") - register_concmd("amx_cvar","cmdCvar",ADMIN_CVAR," [value]") - register_concmd("amx_plugins","cmdPlugins",ADMIN_ADMIN) - register_concmd("amx_modules","cmdModules",ADMIN_ADMIN) - register_concmd("amx_map","cmdMap",ADMIN_MAP,"") - register_concmd("amx_cfg","cmdCfg",ADMIN_CFG,"") - register_concmd("amx_nick","cmdNick",ADMIN_SLAY," ") - register_clcmd("amx_rcon","cmdRcon",ADMIN_RCON,"") - register_clcmd("pauseAck","cmdLBack") -} - -public plugin_cfg() { - // Cvars which can be changed only with rcon access - server_cmd( g_addCvar ,"rcon_password") - server_cmd( g_addCvar ,"amx_show_activity") - server_cmd( g_addCvar ,"amx_mode") - server_cmd( g_addCvar ,"amx_password_field") - server_cmd( g_addCvar ,"amx_default_access") - server_cmd( g_addCvar ,"amx_reserved_slots") - server_cmd( g_addCvar ,"amx_reservation") - server_cmd( g_addCvar ,"amx_conmotd_file") -} - -public cmdKick(id,level,cid) { - if (!cmd_access(id,level,cid,2)) - return PLUGIN_HANDLED - new arg[32] - read_argv(1,arg,31) - new player = cmd_target(id,arg,1) - if (!player) return PLUGIN_HANDLED - new authid[32],authid2[32],name2[32],name[32],userid2,reason[32] - get_user_authid(id,authid,31) - get_user_authid(player,authid2,31) - get_user_name(player,name2,31) - get_user_name(id,name,31) - userid2 = get_user_userid(player) - read_argv(2,reason,31) - remove_quotes(reason) - log_amx("Kick: ^"%s<%d><%s><>^" kick ^"%s<%d><%s><>^" (reason ^"%s^")", - name,get_user_userid(id),authid,name2,userid2,authid2,reason) - switch (get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_KICK_2",name,name2) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_KICK_1",name2) - } - if ( is_user_bot(player) ) - server_cmd("kick #%d",userid2) - else - { - if (reason[0]) - server_cmd("kick #%d ^"%s^"",userid2,reason) - else - server_cmd("kick #%d",userid2) - } - console_print(id,"[AMXX] Client ^"%s^" kicked",name2) - return PLUGIN_HANDLED -} - -public cmdUnban(id,level,cid) { - if (!cmd_access(id,level,cid,2)) - return PLUGIN_HANDLED - new arg[32],authid[32],name[32] - read_argv(1,arg,31) - if (contain(arg,".")!=-1) { - server_cmd("removeip ^"%s^";writeip",arg) - console_print(id,"[AMXX] %L", id, "IP_REMOVED", arg ) - } - else { - server_cmd("removeid ^"%s^";writeid",arg) - console_print(id,"[AMXX] %L", id, "AUTHID_REMOVED", arg ) - } - get_user_name(id,name,31) - switch (get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_UNBAN_2",name,arg) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_UNBAN_1",arg) - } - get_user_authid(id,authid,31) - log_amx("Cmd: ^"%s<%d><%s><>^" unban ^"%s^"", - name,get_user_userid(id),authid, arg ) - return PLUGIN_HANDLED -} - -public cmdAddBan(id,level,cid) { - if (!cmd_access(id,level,cid,3)) - return PLUGIN_HANDLED - new arg[32],authid[32],name[32],minutes[32],reason[32] - read_argv(1,arg,31) - read_argv(2,minutes,31) - read_argv(3,reason,31) - if (contain(arg,".")!=-1) { - server_cmd("addip ^"%s^" ^"%s^";wait;writeip",minutes,arg) - console_print(id,"[AMXX] Ip ^"%s^" added to ban list", arg ) - } - else { - server_cmd("banid ^"%s^" ^"%s^";wait;writeid",minutes,arg) - console_print(id,"[AMXX] Authid ^"%s^" added to ban list", arg ) - } - get_user_name(id,name,31) - switch (get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_ADDBAN_2",name,arg) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_ADDBAN_1",arg) - } - get_user_authid(id,authid,31) - log_amx("Cmd: ^"%s<%d><%s><>^" ban ^"%s^" (minutes ^"%s^") (reason ^"%s^")", - name,get_user_userid(id),authid, arg, minutes, reason ) - return PLUGIN_HANDLED -} - -public cmdBan(id,level,cid) { - if (!cmd_access(id,level,cid,3)) - return PLUGIN_HANDLED - new target[32],minutes[8],reason[64] - read_argv(1,target,31) - read_argv(2,minutes,7) - read_argv(3,reason,63) - new player = cmd_target(id,target,9) - if (!player) return PLUGIN_HANDLED - new authid[32],name2[32],authid2[32],name[32] - new userid2 = get_user_userid(player) - get_user_authid(player,authid2,31) - get_user_authid(id,authid,31) - get_user_name(player,name2,31) - get_user_name(id,name,31) - userid2 = get_user_userid(player) - log_amx("Ban: ^"%s<%d><%s><>^" ban and kick ^"%s<%d><%s><>^" (minutes ^"%s^") (reason ^"%s^")", - name,get_user_userid(id),authid, name2,userid2,authid2,minutes,reason) - - new temp[64],banned[16],nNum = str_to_num(minutes) - if (nNum) - format(temp,63,"%L",player,"FOR_MIN",minutes) - else - format(temp,63,"%L",player,"PERM") - - format(banned,15,"%L",player,"BANNED") - - if (reason[0]) - server_cmd("kick #%d ^"%s (%s %s)^";wait;banid ^"%s^" ^"%s^";wait;writeid",userid2,reason,banned,temp,minutes,authid2) - else - server_cmd("kick #%d ^"%s %s^";wait;banid ^"%s^" ^"%s^";wait;writeid",userid2,banned,temp,minutes,authid2) - - new activity = get_cvar_num("amx_show_activity") - if (activity!=0) { - new players[32],pnum,msg[256],len - get_players(players,pnum,"c") - for (new i=0;i<%s><>^" ban and kick ^"%s<%d><%s><>^" (minutes ^"%s^") (reason ^"%s^")", - name,get_user_userid(id),authid, name2,userid2,authid2,minutes,reason) - - new temp[64],banned[16],nNum = str_to_num(minutes) - if (nNum) - format(temp,63,"%L",player,"FOR_MIN",minutes) - else - format(temp,63,"%L",player,"PERM") - - format(banned,15,"%L",player,"BANNED") - - new address[32] - get_user_ip(player,address,31,1) - - if (reason[0]) - server_cmd("kick #%d ^"%s (%s %s)^";wait;addip ^"%s^" ^"%s^";wait;writeip",userid2,reason,banned,temp,minutes,address) - else - server_cmd("kick #%d ^"%s %s^";wait;addip ^"%s^" ^"%s^";wait;writeip",userid2,banned,temp,minutes,address) - - new activity = get_cvar_num("amx_show_activity") - if (activity!=0) { - new players[32],pnum,msg[256],len - get_players(players,pnum,"c") - for (new i=0;i<%s><>^" slay ^"%s<%d><%s><>^"", - name,get_user_userid(id),authid, name2,get_user_userid(player),authid2 ) - - switch (get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_SLAY_2",name,name2) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_SLAY_1",name2) - } - - console_print(id,"[AMXX] %L",id,"CLIENT_SLAYED",name2) - return PLUGIN_HANDLED -} - -public cmdSlap(id,level,cid) { - if (!cmd_access(id,level,cid,2)) - return PLUGIN_HANDLED - new arg[32] - read_argv(1,arg,31) - new player = cmd_target(id,arg,5) - if (!player) return PLUGIN_HANDLED - new spower[32],authid[32],name2[32],authid2[32],name[32] - read_argv(2,spower,31) - new damage = str_to_num(spower) - user_slap(player,damage) - get_user_authid(id,authid,31) - get_user_name(id,name,31) - get_user_authid(player,authid2,31) - get_user_name(player,name2,31) - log_amx("Cmd: ^"%s<%d><%s><>^" slap with %d damage ^"%s<%d><%s><>^"", - name,get_user_userid(id),authid, damage,name2,get_user_userid(player),authid2 ) - - switch (get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_SLAP_2",name,name2,damage) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_SLAP_1",name2,damage) - } - - console_print(id,"[AMXX] %L",id,"CLIENT_SLAPED",name2,damage) - return PLUGIN_HANDLED -} - -public chMap(map[]) { - server_cmd("changelevel %s",map) -} - -public cmdMap(id,level,cid) { - if (!cmd_access(id,level,cid,2)) - return PLUGIN_HANDLED - new arg[32] - new arglen = read_argv(1,arg,31) - if ( !is_map_valid(arg) ){ - console_print(id,"[AMXX] %L",id,"MAP_NOT_FOUND") - return PLUGIN_HANDLED - } - new authid[32],name[32] - get_user_authid(id,authid,31) - get_user_name(id,name,31) - switch (get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_MAP_2",name,arg) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_MAP_1",arg) - } - log_amx("Cmd: ^"%s<%d><%s><>^" changelevel ^"%s^"", name,get_user_userid(id),authid, arg) - message_begin(MSG_ALL, SVC_INTERMISSION) - message_end() - set_task(2.0,"chMap",0,arg,arglen+1) - return PLUGIN_HANDLED -} - -onlyRcon( name[] ) { - for (new a = 0; a < g_cvarRconNum; ++a) - if ( equal( g_cvarRcon[a] , name) ) - return 1 - return 0 -} - -public cmdCvar(id,level,cid) { - if (!cmd_access(id,level,cid,2)) - return PLUGIN_HANDLED - new arg[32], arg2[64] - read_argv(1,arg,31) - read_argv(2,arg2,63) - if ( equal(arg,"add") && (get_user_flags(id) & ADMIN_RCON) ) { - if ( cvar_exists(arg2) ){ - if ( g_cvarRconNum < MAXRCONCVARS ) - copy( g_cvarRcon[ g_cvarRconNum++ ] , 31, arg2 ) - else - console_print(id,"[AMXX] %L",id,"NO_MORE_CVARS") - } - return PLUGIN_HANDLED - } - if (!cvar_exists(arg)){ - console_print(id,"[AMXX] %L",id,"UNKNOWN_CVAR",arg) - return PLUGIN_HANDLED - } - if ( onlyRcon(arg) && !(get_user_flags(id) & ADMIN_RCON)){ - console_print(id,"[AMXX] %L",id,"CVAR_NO_ACC") - return PLUGIN_HANDLED - } - else if (equal(arg,"sv_password") && !(get_user_flags(id) & ADMIN_PASSWORD)){ - console_print(id,"[AMXX] %L",id,"CVAR_NO_ACC") - return PLUGIN_HANDLED - } - if (read_argc() < 3){ - get_cvar_string(arg,arg2,63) - console_print(id,"[AMXX] %L",id,"CVAR_IS",arg,arg2) - return PLUGIN_HANDLED - } - new authid[32],name[32] - get_user_authid(id,authid,31) - get_user_name(id,name,31) - log_amx("Cmd: ^"%s<%d><%s><>^" set cvar (name ^"%s^") (value ^"%s^")", - name,get_user_userid(id),authid, arg,arg2) - set_cvar_string(arg,arg2) - - new activity = get_cvar_num("amx_show_activity") - if (activity!=0) { - new players[32],pnum,admin[64],cvar_val[64],len - get_players(players,pnum,"c") - for (new i=0;i<%s><>^" execute cfg (file ^"%s^")", - name,get_user_userid(id),authid, arg) - console_print(id,"[AMXX] Executing file ^"%s^"",arg) - server_cmd("exec %s",arg) - - switch(get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_CONF_2",name,arg) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_CONF_1",arg) - } - - return PLUGIN_HANDLED -} - -public cmdLBack() { - new paused[16] - format(paused,15,"%L",g_pauseCon,g_Paused ? "UNPAUSED" : "PAUSED") - set_cvar_float("pausable",g_pausAble) - console_print(g_pauseCon,"[AMXX] Server %s", paused) - if (g_Paused) g_Paused = false - else g_Paused = true - return PLUGIN_HANDLED -} - -public cmdPause(id,level,cid) { - if (!cmd_access(id,level,cid,1)) - return PLUGIN_HANDLED - new authid[32],name[32],slayer = id - get_user_authid(id,authid,31) - get_user_name(id,name,31) - g_pausAble = get_cvar_float("pausable") - if (!slayer) slayer = find_player("h") - if (!slayer) { - console_print(id,"[AMXX] %L",id,"UNABLE_PAUSE") - return PLUGIN_HANDLED - } - set_cvar_float("pausable",1.0) - client_cmd(slayer,"pause;pauseAck") - log_amx("Cmd: ^"%s<%d><%s><>^" %s server", - name,get_user_userid(id),authid, g_Paused ? "unpause" : "pause" ) - new pausing[16] - format(pausing,15,"%L",id,g_Paused ? "UNPAUSING" : "PAUSING") - console_print(id,"[AMXX] %L", id, pausing) - - new activity = get_cvar_num("amx_show_activity") - if (activity!=0) { - new players[32],pnum,msg[128],len - get_players(players,pnum,"c") - for (new i=0;i<%s><>^" server console (cmdline ^"%s^")", - name,get_user_userid(id),authid, arg) - console_print(id,"[AMXX] %L",id,"COM_SENT_SERVER",arg) - server_cmd(arg) - return PLUGIN_HANDLED -} - -public cmdWho(id,level,cid) { - if (!cmd_access(id,level,cid,1)) - return PLUGIN_HANDLED - - new players[32], inum, cl_on_server[64], authid[32], name[32], flags, sflags[32] - new lImm[16],lRes[16],lAccess[16],lYes[16],lNo[16] - format(lImm,15,"%L",id,"IMMU") - format(lRes,15,"%L",id,"RESERV") - format(lAccess,15,"%L",id,"ACCESS") - format(lYes,15,"%L",id,"YES") - format(lNo,15,"%L",id,"NO") - get_players(players,inum) - format(cl_on_server,63,"%L",id,"CLIENTS_ON_SERVER") - console_print(id,"^n%s:^n # %-16.15s %-12s %-8s %-4.3s %-4.3s %s", - cl_on_server,"nick","authid","userid",lImm,lRes,lAccess) - for (new a = 0; a < inum; ++a) { - get_user_authid(players[a],authid,31) - get_user_name(players[a],name,31) - flags = get_user_flags(players[a]) - get_flags(flags,sflags,31) - console_print(id,"%2d %-16.15s %-12s %-8d %-4.3s %-4.3s %s", players[a],name,authid, - get_user_userid(players[a]),(flags&ADMIN_IMMUNITY)?lYes:lNo, - (flags&ADMIN_RESERVATION)?lYes:lNo,sflags) - } - console_print(id,"%L",id,"TOTAL_NUM",inum) - get_user_authid(id,authid,31) - get_user_name(id,name,31) - log_amx("Cmd: ^"%s<%d><%s><>^" ask for players list",name,get_user_userid(id),authid) - return PLUGIN_HANDLED -} - -hasTag(name[],tags[4][32],tagsNum) { - for (new a=0;a<%s><>^" leave some group (tag1 ^"%s^") (tag2 ^"%s^") (tag3 ^"%s^") (tag4 ^"%s^")", - name,get_user_userid(id),authid,ltags[0],ltags[1],ltags[2],ltags[3] ) - - switch(get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_LEAVE_2",name,ltags[0],ltags[1],ltags[2],ltags[3]) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_LEAVE_1",ltags[0],ltags[1],ltags[2],ltags[3]) - } - - return PLUGIN_HANDLED -} - -public cmdNick(id,level,cid) { - if (!cmd_access(id,level,cid,3)) - return PLUGIN_HANDLED - - new arg1[32],arg2[32],authid[32],name[32],authid2[32],name2[32] - - read_argv(1,arg1,31) - read_argv(2,arg2,31) - - new player = cmd_target(id,arg1,1) - if (!player) return PLUGIN_HANDLED - - get_user_authid(id,authid,31) - get_user_name(id,name,31) - get_user_authid(player,authid2,31) - get_user_name(player,name2,31) - - client_cmd(player,"name ^"%s^"",arg2) - - log_amx("Cmd: ^"%s<%d><%s><>^" change nick to ^"%s^" ^"%s<%d><%s><>^"", - name,get_user_userid(id),authid,arg2,name2,get_user_userid(player),authid2 ) - - switch (get_cvar_num("amx_show_activity")) { - case 2: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_NICK_2",name,name2,arg2) - case 1: client_print(0,print_chat,"%L",LANG_PLAYER,"ADMIN_NICK_1",name2,arg2) - } - - console_print(id,"[AMXX] %L",id,"CHANGED_NICK",name2,arg2) - - return PLUGIN_HANDLED -}