RSSy MYGO.pl Opublikowano Grudzień 28, 2020 o 06:50 RSSy Udostępnij Opublikowano Grudzień 28, 2020 o 06:50 i tried to set the amx_plugins command and amx_modules to rcon but ...the others can still acces the commands... any idea? Thanks in advance :twisted: PHP Code: #include <amxmodx>#include <amxmisc>#define MAXRCONCVARS 16new g_cvarRcon[MAXRCONCVARS][32]new g_cvarRconNumnew g_pauseConnew Float:g_pausAblenew bool:g_Pausednew bool:g_PauseAllowed = falsenew g_addCvar[] = "amx_cvar add %s"public plugin_init(){ register_plugin("Admin commands", AMXX_VERSION_STR, "") register_dictionary("admin_cmd.txt") register_dictionary("common.txt") register_concmd("amx_kick", "cmdKick", ADMIN_KICK, "[name or #userid] [reason]") 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_cvar", "cmdCvar", ADMIN_CVAR, "[cvar] [value]") register_concmd("amx_plugins", "cmdPlugins", ADMIN_RCON) register_concmd("amx_modules", "cmdModules", ADMIN_RCON) register_concmd("amx_map", "cmdMap", ADMIN_MAP, "[mapname]") register_concmd("amx_cfg", "cmdCfg", ADMIN_CFG, "[filename]") register_concmd("amx_nick", "cmdNick", ADMIN_SLAY, "[name or #userid] [new nick]") register_clcmd("amx_rcon", "cmdRcon", ADMIN_RCON, "[command line]") register_clcmd("amx_showrcon", "cmdShowRcon", ADMIN_RCON, "[command line]") 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: chat_color(0,"%L", LANG_PLAYER, "ADMIN_KICK_2", name, name2) case 1: chat_color(0,"%L", LANG_PLAYER, "ADMIN_KICK_1", name, 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 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_amx("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: chat_color(0,"%L", LANG_PLAYER, "ADMIN_SLAY_2", name, name2) case 1: chat_color(0,"%L", LANG_PLAYER, "ADMIN_SLAY_1", name , 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: chat_color(0,"%L", LANG_PLAYER, "ADMIN_SLAP_2", name, name2, damage) case 1: chat_color(0,"%L", LANG_PLAYER, "ADMIN_SLAP_1", name , 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: chat_color(0,"%L", LANG_PLAYER, "ADMIN_MAP_2", name, arg) case 1: chat_color(0,"%L", LANG_PLAYER, "ADMIN_MAP_1", name, arg) } log_amx("Cmd: ^"%s<%d><%s><>^" changelevel ^"%s^"", name, get_user_userid(id), authid, arg) new _modName[10] get_modname(_modName, 9) if (!equal(_modName, "zp")) { 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 (equali(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 < pnum; i++) { len = format(admin, 255, "%L", players[i], "ADMIN") if (activity == 1) len += copy(admin[len], 255-len, ":") else len += format(admin[len], 255-len, " %s:", name) if (equal(arg, "rcon_password") || equal(arg, "sv_password")) format(cvar_val, 63, "*** %L ***", players[i], "PROTECTED") else copy(cvar_val, 63, arg2) chat_color(players[i],"%L", players[i], "SET_CVAR_TO", name, arg, arg2) } } console_print(id, "[AMXX] %L", id, "CVAR_CHANGED", arg, arg2) return PLUGIN_HANDLED}public cmdPlugins(id, level, cid){ if (!cmd_access(id, level, cid, 1)) return PLUGIN_HANDLED new name[32], version[32], author[32], filename[32], status[32] new lName[32], lVersion[32], lAuthor[32], lFile[32], lStatus[32] format(lName, 31, "%L", id, "NAME") format(lVersion, 31, "%L", id, "VERSION") format(lAuthor, 31, "%L", id, "AUTHOR") format(lFile, 31, "%L", id, "FILE") format(lStatus, 31, "%L", id, "STATUS") new num = get_pluginsnum() new running = 0 console_print(id, "%L:", id, "LOADED_PLUGINS") console_print(id, "%-18.17s %-8.7s %-17.16s %-16.15s %-9.8s", lName, lVersion, lAuthor, lFile, lStatus) for (new i = 0; i <num; i++) { get_plugin(i, filename, 31, name, 31, version, 31, author, 31, status, 31) console_print(id, "%-18.17s %-8.7s %-17.16s %-16.15s %-9.8s", name, version, author, filename, status) if (status[0]=='d' || status[0]=='r') // "debug" or "running" running++ } console_print(id, "%L", id, "PLUGINS_RUN", num, running) return PLUGIN_HANDLED}public cmdModules(id, level, cid){ if (!cmd_access(id, level, cid, 1)) return PLUGIN_HANDLED new name[32], version[32], author[32], status, sStatus[16] new lName[32], lVersion[32], lAuthor[32] format(lName, 31, "%L", id, "NAME") format(lVersion, 31, "%L", id, "VERSION") format(lAuthor, 31, "%L", id, "AUTHOR") new num = get_modulesnum() console_print(id, "%L:", id, "LOADED_MODULES") console_print(id, "%-23.22s %-8.7s %-20.19s", lName, lVersion, lAuthor) for (new i = 0; i < num; i++) { get_module(i, name, 31, author, 31, version, 31, status) switch (status) { case module_loaded: copy(sStatus, 15, "running") default: copy(sStatus, 15, "error") } console_print(id, "%-23.22s %-8.7s %-20.19s", name, version, author) } console_print(id, "%L", id, "NUM_MODULES", num) 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, "[AMXX] %L", id, "FILE_NOT_FOUND", arg) 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><>^" 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: chat_color(0,"%L", LANG_PLAYER, "ADMIN_CONF_2", name, arg) case 1: chat_color(0,"%L", LANG_PLAYER, "ADMIN_CONF_1", arg) } return PLUGIN_HANDLED}public cmdLBack(){ if (!g_PauseAllowed) return PLUGIN_CONTINUE new paused[25] format(paused, 24, "%L", g_pauseCon, g_Paused ? "UNPAUSED" : "PAUSED") set_cvar_float("pausable", g_pausAble) console_print(g_pauseCon, "[AMXX] Server %s", paused) g_PauseAllowed = false 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) g_PauseAllowed = true client_cmd(slayer, "pause;pauseAck") log_amx("Cmd: ^"%s<%d><%s><>^" %s server", name, get_user_userid(id), authid, g_Paused ? "unpause" : "pause") console_print(id, "[AMXX] %L", id, g_Paused ? "UNPAUSING" : "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 < pnum; i++) { len = format(msg, 127, "%L", players[i], "ADMIN") if (activity == 1) len += copy(msg[len], 127-len, ": ") else len += format(msg[len], 127-len, " %s: ", name) format(msg[len], 127-len, "%L", players[i], g_Paused ? "UNPAUSE" : "PAUSE") client_print(players[i], print_chat, "%s server", msg) } } g_pauseCon = id return PLUGIN_HANDLED} public cmdShowRcon(id, level, cid){ if (!cmd_access(id, level, cid, 2)) return PLUGIN_HANDLED new password[64] get_cvar_string("rcon_password", password, 63) if (!password[0]) { cmdRcon(id, level, cid) } else { new args[128] read_args(args, 127) client_cmd(id, "rcon_password %s", password) client_cmd(id, "rcon %s", args) } 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_amx("Cmd: ^"%s<%d><%s><>^" server console (cmdline ^"%s^")", name, get_user_userid(id), authid, arg) console_print(id, "[AMXX] %L", id, "COM_SENT_SERVER", arg) server_cmd("%s", arg) 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, lReason[128] 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, "[AMXX] %L", id, "SKIP_MATCH", nick, ltags[ires]) continue } if (get_user_flags(b) & ADMIN_IMMUNITY) { console_print(id, "[AMXX] %L", id, "SKIP_IMM", nick) continue } console_print(id, "[AMXX] %L", id, "KICK_PL", nick) if (is_user_bot(b)) server_cmd("kick #%d", get_user_userid(b)) else { format(lReason, 127, "%L", b, "YOU_DROPPED") server_cmd("kick #%d ^"%s^"", get_user_userid(b), lReason) } count++ } console_print(id, "[AMXX] %L", id, "KICKED_CLIENTS", count) new authid[32], name[32] get_user_authid(id, authid, 31) get_user_name(id, name, 31) log_amx("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: chat_color(0,"%L", LANG_PLAYER, "ADMIN_LEAVE_2", name, ltags[0], ltags[1], ltags[2], ltags[3]) case 1: chat_color(0,"%L", LANG_PLAYER, "ADMIN_LEAVE_1", name, 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: chat_color(0,"%L", LANG_PLAYER, "ADMIN_NICK_2", name, name2, arg2) case 1: chat_color(0,"%L", LANG_PLAYER, "ADMIN_NICK_1", name, name2, arg2) } console_print(id, "[AMXX] %L", id, "CHANGED_NICK", name2, arg2) return PLUGIN_HANDLED}stock chat_color(const id, const input[], any:...){ new count = 1, players[32] static msg[191] vformat(msg, 190, input, 3) replace_all(msg, 190, "!g", "^4") replace_all(msg, 190, "!y", "^1") replace_all(msg, 190, "!team", "^3") if (id) players[0] = id; else get_players(players, count, "ch") { for (new i = 0; i < count; i++) { if (is_user_connected(players[i])) { message_begin(MSG_ONE_UNRELIABLE, get_user_msgid("SayText"), _, players[i]) write_byte(players[i]); write_string(msg); message_end(); } } }} Przeczytaj cały wpis Odnośnik do komentarza Udostępnij na innych stronach Więcej opcji udostępniania...
Rekomendowane odpowiedzi