/* 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 #include #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," [reason]") register_concmd("amx_ban","cmdAddBan",ADMIN_BAN," [reason]") register_concmd("amx_banid","cmdBan",ADMIN_BAN," [reason]") register_concmd("amx_banip","cmdBan",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",0,"- displays who is on server") register_concmd("amx_cvar","cmdCvar",ADMIN_CVAR," [value]") register_clcmd("amx_map","cmdMap",ADMIN_MAP,"") register_clcmd("pauseAck","cmdLBack") register_clcmd("amx_cfg","cmdCfg",ADMIN_CFG,"") register_clcmd("amx_rcon","cmdRcon",ADMIN_RCON,"") 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<%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 }