mirror of
https://github.com/alliedmodders/amxmodx.git
synced 2025-01-23 20:28:03 +03:00
471 lines
16 KiB
Plaintext
Executable File
471 lines
16 KiB
Plaintext
Executable File
/* AMX Mod X script.
|
|
*
|
|
* (c) 2002-2004, OLO
|
|
* modified by the AMX Mod X Development Team
|
|
*
|
|
* This file is provided as is (no warranties).
|
|
*/
|
|
|
|
#include <amxmod>
|
|
#include <amxmisc>
|
|
|
|
#define MAXRCONCVARS 16
|
|
new g_cvarRcon[ MAXRCONCVARS ][32]
|
|
new g_cvarRconNum
|
|
new g_logFile[16]
|
|
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","0.1","default")
|
|
register_concmd("amx_kick","cmdKick",ADMIN_KICK,"<name or #userid> [reason]")
|
|
register_concmd("amx_ban","cmdAddBan",ADMIN_BAN,"<authid or ip> <minutes> [reason]")
|
|
register_concmd("amx_banid","cmdBan",ADMIN_BAN,"<name or #userid> <minutes> [reason]")
|
|
register_concmd("amx_banip","cmdBan",ADMIN_BAN,"<name or #userid> <minutes> [reason]")
|
|
register_concmd("amx_unban","cmdUnban",ADMIN_BAN,"<authid or ip>")
|
|
register_concmd("amx_slay","cmdSlay",ADMIN_SLAY,"<name or #userid>")
|
|
register_concmd("amx_slap","cmdSlap",ADMIN_SLAY,"<name or #userid> [power]")
|
|
register_concmd("amx_leave","cmdLeave",ADMIN_KICK,"<tag> [tag] [tag] [tag]")
|
|
register_concmd("amx_pause","cmdPause",ADMIN_CVAR,"- pause or unpause the game")
|
|
register_concmd("amx_who","cmdWho",0,"- displays who is on server")
|
|
register_concmd("amx_cvar","cmdCvar",ADMIN_CVAR,"<cvar> [value]")
|
|
register_clcmd("amx_map","cmdMap",ADMIN_MAP,"<mapname>")
|
|
register_clcmd("pauseAck","cmdLBack")
|
|
register_clcmd("amx_cfg","cmdCfg",ADMIN_CFG,"<fliename>")
|
|
register_clcmd("amx_rcon","cmdRcon",ADMIN_RCON,"<command line>")
|
|
register_cvar("amx_show_activity","2")
|
|
register_cvar("amx_vote_delay","")
|
|
register_cvar("amx_vote_time","")
|
|
register_cvar("amx_vote_answers","")
|
|
register_cvar("amx_vote_ratio","")
|
|
register_cvar("amx_show_activity","")
|
|
get_logfile(g_logFile,15)
|
|
}
|
|
|
|
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_to_file(g_logFile,"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,"ADMIN %s: kick %s",name,name2)
|
|
case 1: client_print(0,print_chat,"ADMIN: kick %s",name2)
|
|
}
|
|
server_cmd("kick #%d ^"%s^"",userid2,reason)
|
|
console_print(id,"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,"Ip ^"%s^" removed from ban list", arg )
|
|
}
|
|
else {
|
|
server_cmd("removeid ^"%s^";writeid",arg)
|
|
console_print(id,"Authid ^"%s^" removed from ban list", arg )
|
|
}
|
|
get_user_name(id,name,31)
|
|
switch(get_cvar_num("amx_show_activity")) {
|
|
case 2: client_print(0,print_chat,"ADMIN %s: unban %s",name,arg)
|
|
case 1: client_print(0,print_chat,"ADMIN: unban %s",arg)
|
|
}
|
|
get_user_authid(id,authid,31)
|
|
log_to_file(g_logFile,"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,"Ip ^"%s^" added to ban list", arg )
|
|
}
|
|
else {
|
|
server_cmd("banid ^"%s^" ^"%s^";wait;writeid",minutes,arg)
|
|
console_print(id,"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,"ADMIN %s: ban %s",name,arg)
|
|
case 1: client_print(0,print_chat,"ADMIN: ban %s",arg)
|
|
}
|
|
get_user_authid(id,authid,31)
|
|
log_to_file(g_logFile,"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 arg[32], cmd[32]
|
|
read_argv(0,cmd,31)
|
|
read_argv(1,arg,31)
|
|
new player = cmd_target(id,arg,9)
|
|
if (!player) return PLUGIN_HANDLED
|
|
new minutes[32],authid[32],name2[32],authid2[32],name[32],reason[32]
|
|
new userid2 = get_user_userid(player)
|
|
read_argv(2,minutes,31)
|
|
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)
|
|
read_argv(3,reason,31)
|
|
log_to_file(g_logFile,"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]
|
|
if (strtonum(minutes))
|
|
format(temp,63,"for %s min.",minutes)
|
|
else
|
|
temp = "permanently"
|
|
|
|
if ( equal(cmd[7],"ip") || (!equal(cmd[7],"id") && get_cvar_num("sv_lan")) ){
|
|
new address[32]
|
|
get_user_ip(player,address,31,1)
|
|
server_cmd("kick #%d ^"%s (banned %s)^";wait;addip ^"%s^" ^"%s^";wait;writeip",userid2,reason,temp,minutes,address)
|
|
}
|
|
else
|
|
server_cmd("kick #%d ^"%s (banned %s)^";wait;banid ^"%s^" ^"%s^";wait;writeid",userid2,reason,temp,minutes,authid2)
|
|
|
|
new activity = get_cvar_num("amx_show_activity")
|
|
if (activity) {
|
|
new temp2[64]
|
|
if (activity == 1)
|
|
temp2 = "ADMIN:"
|
|
else
|
|
format(temp2,63,"ADMIN %s:",name)
|
|
client_print(0,print_chat,"%s ban %s %s",temp2,name2,temp)
|
|
}
|
|
|
|
console_print(id,"Client ^"%s^" banned",name2)
|
|
return PLUGIN_HANDLED
|
|
}
|
|
|
|
public cmdSlay(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
|
|
user_kill(player)
|
|
new authid[32],name2[32],authid2[32],name[32]
|
|
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_to_file(g_logFile,"Cmd: ^"%s<%d><%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,"ADMIN %s: slay %s",name,name2)
|
|
case 1: client_print(0,print_chat,"ADMIN: slay %s",name2)
|
|
}
|
|
|
|
console_print(id,"Client ^"%s^" 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 = strtonum(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_to_file(g_logFile,"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,"ADMIN %s: slap %s with %d damage",name,name2,damage)
|
|
case 1: client_print(0,print_chat,"ADMIN: slap %s with %d damage",name2,damage)
|
|
}
|
|
|
|
console_print(id,"Client ^"%s^" slaped with %d damage",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,"Map with that name not found or map is invalid")
|
|
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,"ADMIN %s: changelevel %s",name,arg)
|
|
case 1: client_print(0,print_chat,"ADMIN: changelevel %s",arg)
|
|
}
|
|
log_to_file(g_logFile,"Cmd: ^"%s<%d><%s><>^" changelevel ^"%s^"", name,get_user_userid(id),authid, arg)
|
|
set_task(1.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,"Can't add more cvars for rcon access!")
|
|
}
|
|
return PLUGIN_HANDLED
|
|
}
|
|
if (!cvar_exists(arg)){
|
|
console_print(id,"Unknown cvar: %s",arg)
|
|
return PLUGIN_HANDLED
|
|
}
|
|
if ( onlyRcon(arg) && !(get_user_flags(id) & ADMIN_RCON)){
|
|
console_print(id,"You have no access to that cvar")
|
|
return PLUGIN_HANDLED
|
|
}
|
|
else if (equal(arg,"sv_password") && !(get_user_flags(id) & ADMIN_PASSWORD)){
|
|
console_print(id,"You have no access to that cvar")
|
|
return PLUGIN_HANDLED
|
|
}
|
|
if (read_argc() < 3){
|
|
get_cvar_string(arg,arg2,63)
|
|
console_print(id,"Cvar ^"%s^" is ^"%s^"",arg,arg2)
|
|
return PLUGIN_HANDLED
|
|
}
|
|
new authid[32],name[32]
|
|
get_user_authid(id,authid,31)
|
|
get_user_name(id,name,31)
|
|
log_to_file(g_logFile,"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) {
|
|
new temp[64]
|
|
if (activity == 1)
|
|
temp = "ADMIN:"
|
|
else
|
|
format(temp,63,"ADMIN %s:",name)
|
|
client_print(0,print_chat,"%s set cvar %s to ^"%s^"",temp,arg,equal(arg,"rcon_password") ? "*** PROTECTED ***" : arg2)
|
|
}
|
|
|
|
console_print(id,"Cvar ^"%s^" changed to ^"%s^"",arg,arg2)
|
|
return PLUGIN_HANDLED
|
|
}
|
|
|
|
public cmdCfg(id,level,cid){
|
|
if (!cmd_access(id,level,cid,2))
|
|
return PLUGIN_HANDLED
|
|
new arg[128]
|
|
read_argv(1,arg,127)
|
|
if (!file_exists(arg)){
|
|
console_print(id,"File ^"%s^" not found",arg)
|
|
return PLUGIN_HANDLED
|
|
}
|
|
new authid[32],name[32]
|
|
get_user_authid(id,authid,31)
|
|
get_user_name(id,name,31)
|
|
log_to_file(g_logFile,"Cmd: ^"%s<%d><%s><>^" execute cfg (file ^"%s^")",
|
|
name,get_user_userid(id),authid, arg)
|
|
console_print(id,"Executing file ^"%s^"",arg)
|
|
server_cmd("exec %s",arg)
|
|
|
|
switch(get_cvar_num("amx_show_activity")) {
|
|
case 2: client_print(0,print_chat,"ADMIN %s: execute config %s",name,arg)
|
|
case 1: client_print(0,print_chat,"ADMIN: execute config %s",arg)
|
|
}
|
|
|
|
return PLUGIN_HANDLED
|
|
}
|
|
|
|
public cmdLBack(){
|
|
set_cvar_float("pausable",g_pausAble)
|
|
console_print(g_pauseCon,"Server %s", g_Paused ? "unpaused" : "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,"Server was unable to pause the game. Real players on server are needed")
|
|
return PLUGIN_HANDLED
|
|
}
|
|
set_cvar_float("pausable",1.0)
|
|
client_cmd(slayer,"pause;pauseAck")
|
|
log_to_file(g_logFile,"Cmd: ^"%s<%d><%s><>^" %s server",
|
|
name,get_user_userid(id),authid, g_Paused ? "unpause" : "pause" )
|
|
console_print(id,"Server proceed %s", g_Paused ? "unpausing" : "pausing")
|
|
|
|
switch(get_cvar_num("amx_show_activity")) {
|
|
case 2: client_print(0,print_chat,"ADMIN %s: %s server",name,g_Paused ? "unpause" : "pause")
|
|
case 1: client_print(0,print_chat,"ADMIN: %s server",g_Paused ? "unpause" : "pause")
|
|
}
|
|
|
|
g_pauseCon = id
|
|
return PLUGIN_HANDLED
|
|
}
|
|
|
|
public cmdRcon(id,level,cid){
|
|
if (!cmd_access(id,level,cid,2))
|
|
return PLUGIN_HANDLED
|
|
new arg[128],authid[32],name[32]
|
|
read_args(arg,127)
|
|
get_user_authid(id,authid,31)
|
|
get_user_name(id,name,31)
|
|
log_to_file(g_logFile,"Cmd: ^"%s<%d><%s><>^" server console (cmdline ^"%s^")",
|
|
name,get_user_userid(id),authid, arg)
|
|
console_print(id,"Commmand line ^"%s^" sent to server console",arg)
|
|
server_cmd(arg)
|
|
return PLUGIN_HANDLED
|
|
}
|
|
|
|
public cmdWho(id,level,cid){
|
|
if (get_user_flags(id)&ADMIN_USER) {
|
|
console_print(id,"You have no access to that command")
|
|
return PLUGIN_HANDLED
|
|
}
|
|
new players[32], inum, authid[32],name[32], flags, sflags[32]
|
|
get_players(players,inum)
|
|
console_print(id,"^nClients on server:^n # %-16.15s %-12s %-8s %-4.3s %-4.3s %s",
|
|
"nick","authid","userid","imm","res","access")
|
|
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)?"yes":"no",
|
|
(flags&ADMIN_RESERVATION)?"yes":"no",sflags)
|
|
}
|
|
console_print(id,"Total %d",inum)
|
|
get_user_authid(id,authid,31)
|
|
get_user_name(id,name,31)
|
|
log_to_file(g_logFile,"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<tagsNum;++a)
|
|
if (contain(name,tags[a])!=-1)
|
|
return a
|
|
return -1
|
|
}
|
|
|
|
public cmdLeave(id,level,cid){
|
|
if (!cmd_access(id,level,cid,2))
|
|
return PLUGIN_HANDLED
|
|
new argnum = read_argc()
|
|
new ltags[4][32]
|
|
new ltagsnum = 0
|
|
for(new a=1;a<5;++a){
|
|
if (a<argnum)
|
|
read_argv(a,ltags[ltagsnum++],31)
|
|
else
|
|
ltags[ltagsnum++][0] = 0
|
|
}
|
|
new nick[32], ires, pnum = get_maxplayers() + 1, count = 0
|
|
for(new b=1;b<pnum;++b){
|
|
if (!is_user_connected(b)&&!is_user_connecting(b)) continue
|
|
get_user_name(b,nick,31)
|
|
ires = hasTag(nick,ltags,ltagsnum)
|
|
if (ires!=-1){
|
|
console_print(id,"Skipping ^"%s^" (matching ^"%s^")",nick,ltags[ires])
|
|
continue
|
|
}
|
|
if (get_user_flags(b)&ADMIN_IMMUNITY){
|
|
console_print(id,"Skipping ^"%s^" (immunity)",nick)
|
|
continue
|
|
}
|
|
console_print(id,"Kicking ^"%s^"",nick)
|
|
if (is_user_bot(b))
|
|
server_cmd("kick #%d",get_user_userid(b))
|
|
else
|
|
client_cmd(b,"echo * You have been dropped because admin has left only specified group of clients;disconnect")
|
|
count++
|
|
}
|
|
console_print(id,"Kicked %d clients",count)
|
|
new authid[32],name[32]
|
|
get_user_authid(id,authid,31)
|
|
get_user_name(id,name,31)
|
|
log_to_file(g_logFile,"Kick: ^"%s<%d><%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,"ADMIN %s: leave %s %s %s %s",name,ltags[0],ltags[1],ltags[2],ltags[3])
|
|
case 1: client_print(0,print_chat,"ADMIN: leave %s %s %s %s",ltags[0],ltags[1],ltags[2],ltags[3])
|
|
}
|
|
|
|
return PLUGIN_HANDLED
|
|
}
|