[Rezolvat] Modificare admincmd

Modificari necesare ale pluginurilor

Moderators: Moderatori ajutatori, Moderatori, Echipa eXtreamCS.com

Post Reply
mr.f3lyx
Membru, skill +2
Membru, skill +2
Posts: 610
Joined: 10 Nov 2013, 20:24
Detinator Steam: Da
Location: Palermo, Italy
Has thanked: 69 times
Been thanked: 17 times

10 Feb 2014, 15:41

Buna am si eu doua pluginuri oare se poate sa fie combinate ?
@-) @-) ^:)^ \m/ :)>-
admincmd | Afiseaza codul
#include <amxmodx>
#include <amxmisc>

// This is not a dynamic array because it would be bad for 24/7 map servers.
#define OLD_CONNECTION_QUEUE 10

new g_pauseCon
new Float:g_pausAble
new bool:g_Paused
new bool:g_PauseAllowed = false
new g_addCvar[] = "amx_cvar add %s"

new pausable;
new rcon_password;

// Old connection queue
new g_Names[OLD_CONNECTION_QUEUE][32];
new g_SteamIDs[OLD_CONNECTION_QUEUE][32];
new g_IPs[OLD_CONNECTION_QUEUE][32];
new g_Access[OLD_CONNECTION_QUEUE];
new g_Tracker;
new g_Size;

stock InsertInfo(id)
{
	
	// Scan to see if this entry is the last entry in the list
	// If it is, then update the name and access
	// If it is not, then insert it again.

	if (g_Size > 0)
	{
		new ip[32]
		new auth[32];

		get_user_authid(id, auth, charsmax(auth));
		get_user_ip(id, ip, charsmax(ip), 1/*no port*/);

		new last = 0;
		
		if (g_Size < sizeof(g_SteamIDs))
		{
			last = g_Size - 1;
		}
		else
		{
			last = g_Tracker - 1;
			
			if (last < 0)
			{
				last = g_Size - 1;
			}
		}
		
		if (equal(auth, g_SteamIDs[last]) &&
			equal(ip, g_IPs[last])) // need to check ip too, or all the nosteams will while it doesn't work with their illegitimate server
		{
			get_user_name(id, g_Names[last], charsmax(g_Names[]));
			g_Access[last] = get_user_flags(id);
			
			return;
		}
	}
	
	// Need to insert the entry
	
	new target = 0;  // the slot to save the info at

	// Queue is not yet full
	if (g_Size < sizeof(g_SteamIDs))
	{
		target = g_Size;
		
		++g_Size;
		
	}
	else
	{
		target = g_Tracker;
		
		++g_Tracker;
		// If we reached the end of the array, then move to the front
		if (g_Tracker == sizeof(g_SteamIDs))
		{
			g_Tracker = 0;
		}
	}
	
	get_user_authid(id, g_SteamIDs[target], charsmax(g_SteamIDs[]));
	get_user_name(id, g_Names[target], charsmax(g_Names[]));
	get_user_ip(id, g_IPs[target], charsmax(g_IPs[]), 1/*no port*/);
	
	g_Access[target] = get_user_flags(id);

}
stock GetInfo(i, name[], namesize, auth[], authsize, ip[], ipsize, &access)
{
	if (i >= g_Size)
	{
		abort(AMX_ERR_NATIVE, "GetInfo: Out of bounds (%d:%d)", i, g_Size);
	}
	
	new target = (g_Tracker + i) % sizeof(g_SteamIDs);
	
	copy(name, namesize, g_Names[target]);
	copy(auth, authsize, g_SteamIDs[target]);
	copy(ip,   ipsize,   g_IPs[target]);
	access = g_Access[target];
	
}
public client_disconnect(id)
{
	if (!is_user_bot(id))
	{
		InsertInfo(id);
	}
}

public plugin_init()
{
	register_plugin("Admin Commands", AMXX_VERSION_STR, "AMXX Dev Team")

	register_dictionary("admincmd.txt")
	register_dictionary("common.txt")
	register_dictionary("adminhelp.txt")
	
	
	register_concmd("amx_kick", "cmdKick", ADMIN_KICK, "<name or #userid> [reason]")
	register_concmd("amx_ban", "cmdBan", ADMIN_BAN, "<name or #userid> <minutes> [reason]")
	register_concmd("amx_banip", "cmdBanIP", ADMIN_BAN, "<name or #userid> <minutes> [reason]")
	register_concmd("amx_addban", "cmdAddBan", ADMIN_BAN, "<^"authid^" or ip> <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", ADMIN_ADMIN, "- displays who is on server")
	register_concmd("amx_cvar", "cmdCvar", ADMIN_CVAR, "<cvar> [value]")
	register_concmd("amx_plugins", "cmdPlugins", ADMIN_IMMUNITY)
	register_concmd("amx_modules", "cmdModules", ADMIN_IMMUNITY)
	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_concmd("amx_last", "cmdLast", ADMIN_BAN, "- list the last few disconnected clients info");
	//register_clcmd("amx_rcon", "cmdRcon", ADMIN_RCON, "<command line>")
	//register_clcmd("amx_showrcon", "cmdShowRcon", ADMIN_RCON, "<command line>")
	//register_clcmd("pauseAck", "cmdLBack")


	rcon_password=get_cvar_pointer("rcon_password");
	pausable=get_cvar_pointer("pausable");
	
	
}

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_sql_table");
	server_cmd(g_addCvar, "amx_sql_host");
	server_cmd(g_addCvar, "amx_sql_user");
	server_cmd(g_addCvar, "amx_sql_pass");
	server_cmd(g_addCvar, "amx_sql_db");
	server_cmd(g_addCvar, "amx_sql_type");

}

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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF)
	
	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)

	show_activity_key("ADMIN_KICK_1", "ADMIN_KICK_2", 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, "[FPN] 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, "[FPN] %L", id, "IP_REMOVED", arg)
	} else {
		server_cmd("removeid %s;writeid", arg)
		console_print(id, "[FPN] %L", id, "AUTHID_REMOVED", arg)
	}

	get_user_name(id, name, 31)

	show_activity_key("ADMIN_UNBAN_1", "ADMIN_UNBAN_2", name, 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
}

/* amx_addban is a special command now.
 * If a user with rcon uses it, it bans the user.  No questions asked.
 * If a user without rcon but with ADMIN_BAN uses it, it will scan the old
 * connection queue, and if it finds the info for a player in it, it will
 * check their old access.  If they have immunity, it will not ban.
 * If they do not have immunity, it will ban.  If the user is not found,
 * it will refuse to ban the target.
 */
 
public cmdAddBan(id, level, cid)
{
	if (!cmd_access(id, level, cid, 3, true)) // check for ADMIN_BAN access
	{
		if (get_user_flags(id) & level) // Getting here means they didn't input enough args
		{
			return PLUGIN_HANDLED;
		}
		if (!cmd_access(id, ADMIN_RCON, cid, 3)) // If somehow they have ADMIN_RCON without ADMIN_BAN, continue
		{
			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 (!(get_user_flags(id) & ADMIN_RCON))
	{
		new bool:canban = false;
		new bool:isip = false;
		// Limited access to this command
		if (equali(arg, "STEAM_ID_PENDING") ||
			equali(arg, "STEAM_ID_LAN") ||
			equali(arg, "HLTV") ||
			equali(arg, "4294967295") ||
			equali(arg, "VALVE_ID_LAN") ||
			equali(arg, "VALVE_ID_PENDING"))
		{
			// Hopefully we never get here, so ML shouldn't be needed
			console_print(id, "Cannot ban %s", arg);
			return PLUGIN_HANDLED;
		}
		
		if (contain(arg, ".") != -1)
		{
			isip = true;
		}
		
		// Scan the disconnection queue
		if (isip)
		{
			new IP[32];
			new Name[32];
			new dummy[1];
			new Access;
			for (new i = 0; i < g_Size; i++)
			{
				GetInfo(i, Name, charsmax(Name), dummy, 0, IP, charsmax(IP), Access);
				
				if (equal(IP, arg))
				{
					if (Access & ADMIN_IMMUNITY)
					{
						console_print(id, "[FPN] %s : %L", IP, id, "CLIENT_IMM", Name);
						
						return PLUGIN_HANDLED;
					}
					// User did not have immunity
					canban = true;
				}
			}
		}
		else
		{
			new Auth[32];
			new Name[32];
			new dummy[1];
			new Access;
			for (new i = 0; i < g_Size; i++)
			{
				GetInfo(i, Name, charsmax(Name), Auth, charsmax(Auth), dummy, 0, Access);
				
				if (equal(Auth, arg))
				{
					if (Access & ADMIN_IMMUNITY)
					{
						console_print(id, "[FPN] %s : %L", Auth, id, "CLIENT_IMM", Name);
						
						return PLUGIN_HANDLED;
					}
					// User did not have immunity
					canban = true;
				}
			}
		}
		
		if (!canban)
		{
			console_print(id, "[FPN] You may only ban recently disconnected clients.  Use ^"amx_last^" to view.");
			
			return PLUGIN_HANDLED;
		}
		
	}
	
	// User has access to ban their target
	if (contain(arg, ".") != -1)
	{
		server_cmd("addip ^"%s^" ^"%s^";wait;writeip", minutes, arg)
		console_print(id, "[FPN] Ip ^"%s^" added to ban list", arg)
	} else {
		server_cmd("banid ^"%s^" ^"%s^";wait;writeid", minutes, arg)
		console_print(id, "[FPN] Authid ^"%s^" added to ban list", arg)
	}

	get_user_name(id, name, 31)

	show_activity_key("ADMIN_ADDBAN_1", "ADMIN_ADDBAN_2", name, 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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_NO_BOTS | CMDTARGET_ALLOW_SELF)
	
	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)
	
	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)

	
	// Display the message to all clients

	new msg[256];
	new len;
	new maxpl = get_maxplayers();
	for (new i = 1; i <= maxpl; i++)
	{
		if (is_user_connected(i) && !is_user_bot(i))
		{
			len = formatex(msg, charsmax(msg), "%L", i, "BAN");
			len += formatex(msg[len], charsmax(msg) - len, " %s ", name2);
			if (nNum)
			{
				formatex(msg[len], charsmax(msg) - len, "%L", i, "FOR_MIN", minutes);
			}
			else
			{
				formatex(msg[len], charsmax(msg) - len, "%L", i, "PERM");
			}
			if (strlen(reason) > 0)
			{
				formatex(msg[len], charsmax(msg) - len, " (%L: %s)", i, "REASON", reason);
			}
			show_activity_id(i, id, name, msg);
		}
	}
	
	console_print(id, "[FPN] %L", id, "CLIENT_BANNED", name2)
	
	return PLUGIN_HANDLED
}

public cmdBanIP(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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_NO_BOTS | CMDTARGET_ALLOW_SELF)
	
	if (!player)
	{
		// why is this here?
		// no idea
		// player = cmd_target(id, target, 9);
		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)
	
	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")

	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)

	// Display the message to all clients

	new msg[256];
	new len;
	new maxpl = get_maxplayers();
	for (new i = 1; i <= maxpl; i++)
	{
		if (is_user_connected(i) && !is_user_bot(i))
		{
			len = formatex(msg, charsmax(msg), "%L", i, "BAN");
			len += formatex(msg[len], charsmax(msg) - len, " %s ", name2);
			if (nNum)
			{
				formatex(msg[len], charsmax(msg) - len, "%L", i, "FOR_MIN", minutes);
			}
			else
			{
				formatex(msg[len], charsmax(msg) - len, "%L", i, "PERM");
			}
			if (strlen(reason) > 0)
			{
				formatex(msg[len], charsmax(msg) - len, " (%L: %s)", i, "REASON", reason);
			}
			show_activity_id(i, id, name, msg);
		}
	}

	console_print(id, "[FPN] %L", id, "CLIENT_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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF | CMDTARGET_ONLY_ALIVE)
	
	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)

	show_activity_key("ADMIN_SLAY_1", "ADMIN_SLAY_2", name, name2);

	console_print(id, "[FPN] %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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF | CMDTARGET_ONLY_ALIVE)
	
	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)
	
	if(damage < 0)
	{
		console_print(id, "Nu poti da slap cu valori negative")
		return PLUGIN_HANDLED;
	}
	
	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)

	show_activity_key("ADMIN_SLAP_1", "ADMIN_SLAP_2", name, name2, damage);

	console_print(id, "[FPN] %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, "[FPN] %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)
	
	show_activity_key("ADMIN_MAP_1", "ADMIN_MAP_2", 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
}

stock bool:onlyRcon(const name[])
{
	new pentru=get_cvar_pointer(name);
	if (pentru && get_pcvar_flags(pentru) & FCVAR_PROTECTED)
	{
		return true;
	}
	return false;
}

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)
	
	new pointer;
	
	if (equal(arg, "add") && (get_user_flags(id) & ADMIN_RCON))
	{
		if ((pointer=get_cvar_pointer(arg2))!=0)
		{
			new flags=get_pcvar_flags(pointer);
			
			if (!(flags & FCVAR_PROTECTED))
			{
				set_pcvar_flags(pointer,flags | FCVAR_PROTECTED);
			}
		}
		return PLUGIN_HANDLED
	}
	
	if ((pointer=get_cvar_pointer(arg))==0)
	{
		console_print(id, "[FPN] %L", id, "UNKNOWN_CVAR", arg)
		return PLUGIN_HANDLED
	}
	
	if (onlyRcon(arg) && !(get_user_flags(id) & ADMIN_RCON))
	{
		// Exception for the new onlyRcon rules:
		//   sv_password is allowed to be modified by ADMIN_PASSWORD
		if (!(equali(arg,"sv_password") && (get_user_flags(id) & ADMIN_PASSWORD)))
		{
			console_print(id, "[FPN] %L", id, "CVAR_NO_ACC")
			return PLUGIN_HANDLED
		}
	}
	
	if (read_argc() < 3)
	{
		get_pcvar_string(pointer, arg2, 63)
		console_print(id, "[FPN] %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)
	
	
	// Display the message to all clients

	new cvar_val[64];
	new maxpl = get_maxplayers();
	for (new i = 1; i <= maxpl; i++)
	{
		if (is_user_connected(i) && !is_user_bot(i))
		{
			if (get_pcvar_flags(pointer) & FCVAR_PROTECTED || equali(arg, "rcon_password"))
			{
				formatex(cvar_val, charsmax(cvar_val), "*** %L ***", i, "PROTECTED");
			}
			else
			{
				copy(cvar_val, charsmax(cvar_val), arg2);
			}
			show_activity_id(i, id, name, "%L", i, "SET_CVAR_TO", "", arg, cvar_val);
		}
	}

	console_print(id, "[FPN] %L", id, "CVAR_CHANGED", arg, arg2)
	
	return PLUGIN_HANDLED
}

public cmdPlugins(id, level, cid)
{
	if (!cmd_access(id, level, cid, 1))
		return PLUGIN_HANDLED
		
	if (id==0) // If server executes redirect this to "amxx plugins" for more in depth output
	{
		server_cmd("amxx plugins");
		server_exec();
		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 StartPLID=0;
	new EndPLID;

	new Temp[96]

	new num = get_pluginsnum()
	
	if (read_argc() > 1)
	{
		read_argv(1,Temp,sizeof(Temp)-1);
		StartPLID=str_to_num(Temp)-1; // zero-based
	}

	EndPLID=min(StartPLID + 10, num);
	
	new running = 0
	
	console_print(id, "----- %L -----", id, "LOADED_PLUGINS")
	console_print(id, "%-18.17s %-11.10s %-17.16s %-16.15s %-9.8s", lName, lVersion, lAuthor, lFile, lStatus)

	new i=StartPLID;
	while (i <EndPLID)
	{
		get_plugin(i++, filename, 31, name, 31, version, 31, author, 31, status, 31)
		console_print(id, "%-18.17s %-11.10s %-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", EndPLID-StartPLID, running)
	console_print(id, "----- %L -----",id,"HELP_ENTRIES",StartPLID + 1,EndPLID,num);
	
	if (EndPLID < num)
	{
		formatex(Temp,sizeof(Temp)-1,"----- %L -----",id,"HELP_USE_MORE", EndPLID + 1);
		replace_all(Temp,sizeof(Temp)-1,"amx_help","amx_plugins");
		console_print(id,"%s",Temp);
	}
	else
	{
		formatex(Temp,sizeof(Temp)-1,"----- %L -----",id,"HELP_USE_BEGIN");
		replace_all(Temp,sizeof(Temp)-1,"amx_help","amx_plugins");
		console_print(id,"%s",Temp);
	}

	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], lStatus[32];

	format(lName, 31, "%L", id, "NAME")
	format(lVersion, 31, "%L", id, "VERSION")
	format(lAuthor, 31, "%L", id, "AUTHOR")
	format(lStatus, charsmax(lStatus), "%L", id, "STATUS")

	new num = get_modulesnum()
	
	console_print(id, "%L:", id, "LOADED_MODULES")
	console_print(id, "%-23.22s %-11.10s %-20.19s %-11.10s", lName, lVersion, lAuthor, lStatus)
	
	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, "bad load");
				copy(name, charsmax(name), "unknown");
				copy(author, charsmax(author), "unknown");
				copy(version, charsmax(version), "unknown");
			}
		}
		
		console_print(id, "%-23.22s %-11.10s %-20.19s %-11.10s", name, version, author, sStatus)
	}
	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, "[FPN] %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, "[FPN] Executing file ^"%s^"", arg)
	server_cmd("exec %s", arg)

	show_activity_key("ADMIN_CONF_1", "ADMIN_CONF_2", name, 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, "[FPN] 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) 
	if (pausable!=0)
	{
		g_pausAble = get_pcvar_float(pausable)
	}
	
	if (!slayer)
		slayer = find_player("h") 
	
	if (!slayer)
	{ 
		console_print(id, "[FPN] %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, "[FPN] %L", id, g_Paused ? "UNPAUSING" : "PAUSING")

	// Display the message to all clients

	new maxpl = get_maxplayers();
	for (new i = 1; i <= maxpl; i++)
	{
		if (is_user_connected(i) && !is_user_bot(i))
		{
			show_activity_id(i, id, name, "%L server", i, g_Paused ? "UNPAUSE" : "PAUSE");
		}
	}

	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_pcvar_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, "[FPN] %L", id, "COM_SENT_SERVER", arg)
	server_cmd("%s", 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 %-20s %-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 %-20s %-8d %-6.5s %-6.5s %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 < 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, "[FPN] %L", id, "SKIP_MATCH", nick, ltags[ires])
			continue
		}
		
		if (get_user_flags(b) & ADMIN_IMMUNITY)
		{
			console_print(id, "[FPN] %L", id, "SKIP_IMM", nick)
			continue
		}
		
		console_print(id, "[FPN] %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, "[FPN] %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])

	show_activity_key("ADMIN_LEAVE_1", "ADMIN_LEAVE_2", 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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF)
	
	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)

	show_activity_key("ADMIN_NICK_1", "ADMIN_NICK_2", name, name2, arg2);

	console_print(id, "[FPN] %L", id, "CHANGED_NICK", name2, arg2)

	return PLUGIN_HANDLED
}

public cmdLast(id, level, cid)
{
	if (!cmd_access(id, level, cid, 1))
	{
		return PLUGIN_HANDLED;
	}
	
	new name[32];
	new authid[32];
	new ip[32];
	new flags[32];
	new access;
	
	
	// This alignment is a bit weird (it should grow if the name is larger)
	// but otherwise for the more common shorter name, it'll wrap in server console
	// Steam client display is all skewed anyway because of the non fixed font.
	console_print(id, "%19s %20s %15s %s", "name", "authid", "ip", "access");
	
	for (new i = 0; i < g_Size; i++)
	{
		GetInfo(i, name, charsmax(name), authid, charsmax(authid), ip, charsmax(ip), access);
		
		get_flags(access, flags, charsmax(flags));
		
		console_print(id, "%19s %20s %15s %s", name, authid, ip, flags);
	}
	
	console_print(id, "%d old connections saved.", g_Size);
	
	return PLUGIN_HANDLED;
}

Si
new style ban | Afiseaza codul
#include <amxmodx>
#include <amxmisc>

#define PLUGIN "NewStyleBan"
#define VERSION "1.2"
#define AUTHOR "x"
#define ADMIN_ACCESS ADMIN_BAN

new player_ss,logs,ban_show_chat
new minutes[8], reason[64]

new const site[]= "****"
new const msg_motd []= "Ai primit ban!"
new const gwait[] = "wait;wait;wait"
new const command[]= "amx_ban"

public plugin_init() {
    
   register_plugin(PLUGIN, VERSION, AUTHOR)
   register_dictionary("admincmd.txt")
   register_dictionary("common.txt")
   register_concmd(command,"cmdNewBAN",ADMIN_ACCESS,"<target> Dai ban")
   player_ss = register_cvar("ban_ss","1")
   logs = register_cvar("ban_logs","1")
   ban_show_chat = register_cvar("ban_chat_show","1")
}

public cmdNewBAN(id, level, cid)
{
   if (!cmd_access(id, level, cid, 2))
      return PLUGIN_HANDLED
   new target[32]
   
   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],admin_name[32], name2[32], authid2[32], name[32]
   new userid2 = get_user_userid(player)
   
   new motd[1501],len
   new sztime[54], Ip[32], hostname[64], szdata[54]
   
   get_user_authid(player, authid2, 31)
   get_user_authid(id, authid, 31)
   get_user_name(id, admin_name, 31)
   get_user_name(player, name2, 31)
   get_user_name(id, name, 31)
   
   get_time("%m.%d.%Y",szdata, 53)
   get_time("%H:%M:%S",sztime, 53)
   get_user_ip(player, Ip, 31, 1)
   get_cvar_string("hostname",hostname, 63)
   
   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(get_pcvar_num(player_ss) == 1 )
   {
      set_hudmessage(0, 255, 0, 0.39, 0.29, 0, 6.0, 10.0)
      show_hudmessage(id,"[ New Style Ban ] IP-ul tau: %s",Ip)
      
      client_print(player,print_chat,"** Sa executat comanda ^"%s^" asaupra ta!",command)
      client_print(player,print_chat,"** Numele tau: %s, IP-ul tau: %s, Banat de: %s, POSTEZI POZELE PE: %s",name2,Ip,admin_name,site)
      client_cmd(player,"spk ^"vox/bizwarn.screen.screen.screen^"") 
      client_cmd(player,"snapshot;%s;snapshot;%s;snapshot",gwait, gwait)
   }
   /********************************************************************************/
   if(get_pcvar_num(ban_show_chat) == 1 )
   {
      client_print(0,print_chat,"***ADMIN:%s la banat pe:%s Minute:^"%s^" Motiv:^"%s^"",admin_name,name2,minutes,reason)
   }
   /********************************************************************************/
   if(get_pcvar_num(logs) == 1 )
   {
      new szFile[128]
      get_configsdir(szFile,127)
      formatex(szFile,127,"%s/ban_logs.txt",szFile)
   
      if(!file_exists(szFile))
      {
         write_file(szFile,"Log'S Ban:",-1)
         write_file(szFile,"(c) PoSiTiOn Of PoWeR",-1)
         write_file(szFile," ",-1)
      }
      new szLog[256]
   
      formatex(szLog,255,"Admin: %s , la banat pe %s , in Data %s - Ora %s , Motiv: %s , Minute: %s ",admin_name,name2,szdata,sztime,reason,minutes)
      write_file(szFile,szLog,-1)
      write_file(szFile," ",-1)

   }
   /********************************************************************************/
   len = format(motd, 1500,"<body bgcolor=#000000><font color=#87cefa><pre>")
   len += format(motd[len], 1500-len,"<center><h4><font color=^"blue^">%s</font></h4><¢er>",hostname)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>DATA: %s - Ora: %s</B></color></left>^n",szdata,sztime)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Motiv: %s</B></color></left>^n",reason)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Ip: %s</B></color></left>^n",Ip)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Timp: %s minute</B></color></left>^n",minutes)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Admin: %s </B></color></left>^n",admin_name)
   len += format(motd[len], 1500-len,"<left><font color=^"blue^">*pentru unban: postezi pozele pe %s</color></left>^n^n",site)
   show_motd(player,motd,msg_motd)
   /********************************************************************************/
   if (reason[0])
      set_task(9.0,"cmdban_reason",player)
   else
      set_task(10.0,"cmdban_no_reason",player)
   /********************************************************************************/
   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 < pnum; i++)
      {
         len = format(msg, 255, "%L", players, "ADMIN")
         
         if (activity == 1)
            len += copy(msg[len], 255-len, ":")
         else
            len += format(msg[len], 255-len, " %s:", name)
         
         len += format(msg[len], 255-len, " %L", players, "BAN")
         len += format(msg[len], 255-len, " %s ", name2)
      
         if (nNum)
            format(msg[len], 255-len, "%L", players, "FOR_MIN", minutes)
         else
            format(msg[len], 255-len, "%L", players, "PERM")
         
         client_print(players, print_chat, "%s", msg)
      }
   }
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip) 
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip) 
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip) 
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip)
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip)
   console_print(id,"[AMXX] %L", id, "CLIENT_BANNED", name2)
   
   return PLUGIN_HANDLED
}

public cmdban_reason(player)
{
   new authid2[32],userid2
   
   userid2 = get_user_userid(player)
   
   get_user_authid(player, authid2, 31)
   
   new address[32],g_Reason[32]
   
   get_user_ip(player, address, 31, 1)
   
   new temp[64], banned[16], nNum
   
   nNum = str_to_num(minutes)
   
   copy(g_Reason, 31, reason)
   
   if (nNum)
      format(temp, 63, "%L", player, "FOR_MIN", minutes)
   else
      format(temp, 63, "%L", player, "PERM")
   
   format(banned, 15, "%L", player, "BANNED")
   
   server_cmd("kick #%d ^"%s (%s %s)^";wait;addip ^"%s^" ^"%s^";wait;writeip", userid2, g_Reason, banned, temp, minutes, address)
}

public cmdban_no_reason(player)
{
   new authid2[32], userid2, temp[64], banned[16], nNum
   
   userid2 = get_user_userid(player)
   
   get_user_authid(player, authid2, 31)
   
   new address[32]
   
   get_user_ip(player, address, 31, 1)
   
   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")
   
   server_cmd("kick #%d ^"%s %s^";wait;addip ^"%s^" ^"%s^";wait;writeip", userid2, banned, temp, minutes, address)
}


Va multumesc anticipat celor care incearca sa ma ajute !
Last edited by Adventx on 25 Mar 2014, 18:47, edited 1 time in total.
Reason: Rezolvat!
RoyalServer 2
User avatar
h4wk
Fost moderator
Fost moderator
Posts: 3806
Joined: 22 Sep 2009, 13:10
Detinator Steam: Da
Reputatie: Fost eXtream Mod
Nume anterior : DaZ , zimpe , Dan eXtream
Location: Iasi
Has thanked: 306 times
Been thanked: 321 times
Contact:

10 Feb 2014, 15:59

Nu sunt erori la compilare,insa nu stiu daca functioneaza !
| Afiseaza codul
#include <amxmodx>
#include <amxmisc>

// This is not a dynamic array because it would be bad for 24/7 map servers.
#define OLD_CONNECTION_QUEUE 10

new g_pauseCon
new Float:g_pausAble
new bool:g_Paused
new bool:g_PauseAllowed = false
new g_addCvar[] = "amx_cvar add %s"

new pausable;
new rcon_password;

#define ADMIN_ACCESS ADMIN_BAN

// Old connection queue
new g_Names[OLD_CONNECTION_QUEUE][32];
new g_SteamIDs[OLD_CONNECTION_QUEUE][32];
new g_IPs[OLD_CONNECTION_QUEUE][32];
new g_Access[OLD_CONNECTION_QUEUE];
new g_Tracker;
new g_Size;

new player_ss,logs,ban_show_chat
new minutes[8], reason[64]

new const site[]= "http://felixpenet.forumz.ro"
new const msg_motd []= "Ai primit ban!"
new const gwait[] = "wait;wait;wait"
new const command[]= "amx_bann"

stock InsertInfo(id)
{
    	
    // Scan to see if this entry is the last entry in the list
    // If it is, then update the name and access
    // If it is not, then insert it again.

    if (g_Size > 0)
    {
    	new ip[32]
    	new auth[32];

    	get_user_authid(id, auth, charsmax(auth));
    	get_user_ip(id, ip, charsmax(ip), 1/*no port*/);

    	new last = 0;
    	
    	if (g_Size < sizeof(g_SteamIDs))
    	{
    		last = g_Size - 1;
    	}
    	else
    	{
    		last = g_Tracker - 1;
    			
    		if (last < 0)
    		{
    			last = g_Size - 1;
    		}
    	}
    		
    	if (equal(auth, g_SteamIDs[last]) &&
    			equal(ip, g_IPs[last])) // need to check ip too, or all the nosteams will while it doesn't work with their illegitimate server
    	{
    			get_user_name(id, g_Names[last], charsmax(g_Names[]));
    			g_Access[last] = get_user_flags(id);
    			
    			return;
    		}
    	}
    	
    	// Need to insert the entry
    	
    	new target = 0;  // the slot to save the info at

    	// Queue is not yet full
    	if (g_Size < sizeof(g_SteamIDs))
    	{
    		target = g_Size;
    		
    		++g_Size;
    		
    	}
    	else
    	{
    		target = g_Tracker;
    		
    		++g_Tracker;
    		// If we reached the end of the array, then move to the front
    		if (g_Tracker == sizeof(g_SteamIDs))
    		{
    			g_Tracker = 0;
    		}
    	}
    	
    	get_user_authid(id, g_SteamIDs[target], charsmax(g_SteamIDs[]));
    	get_user_name(id, g_Names[target], charsmax(g_Names[]));
    	get_user_ip(id, g_IPs[target], charsmax(g_IPs[]), 1/*no port*/);
    	
    	g_Access[target] = get_user_flags(id);

    }
    stock GetInfo(i, name[], namesize, auth[], authsize, ip[], ipsize, &access)
    {
    	if (i >= g_Size)
    	{
    		abort(AMX_ERR_NATIVE, "GetInfo: Out of bounds (%d:%d)", i, g_Size);
    	}
    	
    	new target = (g_Tracker + i) % sizeof(g_SteamIDs);
    	
    	copy(name, namesize, g_Names[target]);
    	copy(auth, authsize, g_SteamIDs[target]);
    	copy(ip,   ipsize,   g_IPs[target]);
    	access = g_Access[target];
    	
    }
    public client_disconnect(id)
    {
    	if (!is_user_bot(id))
    	{
    		InsertInfo(id);
    	}
    }

    public plugin_init()
    {
    	register_plugin("Admin Commands", AMXX_VERSION_STR, "AMXX Dev Team")

    	register_dictionary("admincmd.txt")
    	register_dictionary("common.txt")
    	register_dictionary("adminhelp.txt")
    	
    	
    	register_concmd("amx_kick", "cmdKick", ADMIN_KICK, "<name or #userid> [reason]")
    	register_concmd("amx_ban", "cmdBan", ADMIN_BAN, "<name or #userid> <minutes> [reason]")
    	register_concmd("amx_banip", "cmdBanIP", ADMIN_BAN, "<name or #userid> <minutes> [reason]")
    	register_concmd("amx_addban", "cmdAddBan", ADMIN_BAN, "<^"authid^" or ip> <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", ADMIN_ADMIN, "- displays who is on server")
    	register_concmd("amx_cvar", "cmdCvar", ADMIN_CVAR, "<cvar> [value]")
    	register_concmd("amx_plugins", "cmdPlugins", ADMIN_IMMUNITY)
    	register_concmd("amx_modules", "cmdModules", ADMIN_IMMUNITY)
    	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_concmd("amx_last", "cmdLast", ADMIN_BAN, "- list the last few disconnected clients info");
    	//register_clcmd("amx_rcon", "cmdRcon", ADMIN_RCON, "<command line>")
    	//register_clcmd("amx_showrcon", "cmdShowRcon", ADMIN_RCON, "<command line>")
    	//register_clcmd("pauseAck", "cmdLBack")


    	rcon_password=get_cvar_pointer("rcon_password");
    	pausable=get_cvar_pointer("pausable");
    	
    	
    }

    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_sql_table");
    	server_cmd(g_addCvar, "amx_sql_host");
    	server_cmd(g_addCvar, "amx_sql_user");
    	server_cmd(g_addCvar, "amx_sql_pass");
    	server_cmd(g_addCvar, "amx_sql_db");
    	server_cmd(g_addCvar, "amx_sql_type");
		
		//
		register_dictionary("admincmd.txt")
		register_dictionary("common.txt")
		register_concmd(command,"cmdNewBAN",ADMIN_ACCESS,"<target> Dai ban")
		player_ss = register_cvar("ban_ss","1")
		logs = register_cvar("ban_logs","1")
		ban_show_chat = register_cvar("ban_chat_show","1")

    }

    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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF)
    	
    	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)

    	show_activity_key("ADMIN_KICK_1", "ADMIN_KICK_2", 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, "[FPN] 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, "[FPN] %L", id, "IP_REMOVED", arg)
    	} else {
    		server_cmd("removeid %s;writeid", arg)
    		console_print(id, "[FPN] %L", id, "AUTHID_REMOVED", arg)
    	}

    	get_user_name(id, name, 31)

    	show_activity_key("ADMIN_UNBAN_1", "ADMIN_UNBAN_2", name, 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
    }

    /* amx_addban is a special command now.
     * If a user with rcon uses it, it bans the user.  No questions asked.
     * If a user without rcon but with ADMIN_BAN uses it, it will scan the old
     * connection queue, and if it finds the info for a player in it, it will
     * check their old access.  If they have immunity, it will not ban.
     * If they do not have immunity, it will ban.  If the user is not found,
     * it will refuse to ban the target.
     */
     
    public cmdAddBan(id, level, cid)
    {
    	if (!cmd_access(id, level, cid, 3, true)) // check for ADMIN_BAN access
    	{
    		if (get_user_flags(id) & level) // Getting here means they didn't input enough args
    		{
    			return PLUGIN_HANDLED;
    		}
    		if (!cmd_access(id, ADMIN_RCON, cid, 3)) // If somehow they have ADMIN_RCON without ADMIN_BAN, continue
    		{
    			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 (!(get_user_flags(id) & ADMIN_RCON))
    	{
    		new bool:canban = false;
    		new bool:isip = false;
    		// Limited access to this command
    		if (equali(arg, "STEAM_ID_PENDING") ||
    			equali(arg, "STEAM_ID_LAN") ||
    			equali(arg, "HLTV") ||
    			equali(arg, "4294967295") ||
    			equali(arg, "VALVE_ID_LAN") ||
    			equali(arg, "VALVE_ID_PENDING"))
    		{
    			// Hopefully we never get here, so ML shouldn't be needed
    			console_print(id, "Cannot ban %s", arg);
    			return PLUGIN_HANDLED;
    		}
    		
    		if (contain(arg, ".") != -1)
    		{
    			isip = true;
    		}
    		
    		// Scan the disconnection queue
    		if (isip)
    		{
    			new IP[32];
    			new Name[32];
    			new dummy[1];
    			new Access;
    			for (new i = 0; i < g_Size; i++)
    			{
    				GetInfo(i, Name, charsmax(Name), dummy, 0, IP, charsmax(IP), Access);
    				
    				if (equal(IP, arg))
    				{
    					if (Access & ADMIN_IMMUNITY)
    					{
    						console_print(id, "[FPN] %s : %L", IP, id, "CLIENT_IMM", Name);
    						
    						return PLUGIN_HANDLED;
    					}
    					// User did not have immunity
    					canban = true;
    				}
    			}
    		}
    		else
    		{
    			new Auth[32];
    			new Name[32];
    			new dummy[1];
    			new Access;
    			for (new i = 0; i < g_Size; i++)
    			{
    				GetInfo(i, Name, charsmax(Name), Auth, charsmax(Auth), dummy, 0, Access);
    				
    				if (equal(Auth, arg))
    				{
    					if (Access & ADMIN_IMMUNITY)
    					{
    						console_print(id, "[FPN] %s : %L", Auth, id, "CLIENT_IMM", Name);
    						
    						return PLUGIN_HANDLED;
    					}
    					// User did not have immunity
    					canban = true;
    				}
    			}
    		}
    		
    		if (!canban)
    		{
    			console_print(id, "[FPN] You may only ban recently disconnected clients.  Use ^"amx_last^" to view.");
    			
    			return PLUGIN_HANDLED;
    		}
    		
    	}
    	
    	// User has access to ban their target
    	if (contain(arg, ".") != -1)
    	{
    		server_cmd("addip ^"%s^" ^"%s^";wait;writeip", minutes, arg)
    		console_print(id, "[FPN] Ip ^"%s^" added to ban list", arg)
    	} else {
    		server_cmd("banid ^"%s^" ^"%s^";wait;writeid", minutes, arg)
    		console_print(id, "[FPN] Authid ^"%s^" added to ban list", arg)
    	}

    	get_user_name(id, name, 31)

    	show_activity_key("ADMIN_ADDBAN_1", "ADMIN_ADDBAN_2", name, 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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_NO_BOTS | CMDTARGET_ALLOW_SELF)
    	
    	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)
    	
    	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)

    	
    	// Display the message to all clients

    	new msg[256];
    	new len;
    	new maxpl = get_maxplayers();
    	for (new i = 1; i <= maxpl; i++)
    	{
    		if (is_user_connected(i) && !is_user_bot(i))
    		{
    			len = formatex(msg, charsmax(msg), "%L", i, "BAN");
    			len += formatex(msg[len], charsmax(msg) - len, " %s ", name2);
    			if (nNum)
    			{
    				formatex(msg[len], charsmax(msg) - len, "%L", i, "FOR_MIN", minutes);
    			}
    			else
    			{
    				formatex(msg[len], charsmax(msg) - len, "%L", i, "PERM");
    			}
    			if (strlen(reason) > 0)
    			{
    				formatex(msg[len], charsmax(msg) - len, " (%L: %s)", i, "REASON", reason);
    			}
    			show_activity_id(i, id, name, msg);
    		}
    	}
    	
    	console_print(id, "[FPN] %L", id, "CLIENT_BANNED", name2)
    	
    	return PLUGIN_HANDLED
    }

    public cmdBanIP(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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_NO_BOTS | CMDTARGET_ALLOW_SELF)
    	
    	if (!player)
    	{
    		// why is this here?
    		// no idea
    		// player = cmd_target(id, target, 9);
    		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)
    	
    	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")

    	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)

    	// Display the message to all clients

    	new msg[256];
    	new len;
    	new maxpl = get_maxplayers();
    	for (new i = 1; i <= maxpl; i++)
    	{
    		if (is_user_connected(i) && !is_user_bot(i))
    		{
    			len = formatex(msg, charsmax(msg), "%L", i, "BAN");
    			len += formatex(msg[len], charsmax(msg) - len, " %s ", name2);
    			if (nNum)
    			{
    				formatex(msg[len], charsmax(msg) - len, "%L", i, "FOR_MIN", minutes);
    			}
    			else
    			{
    				formatex(msg[len], charsmax(msg) - len, "%L", i, "PERM");
    			}
    			if (strlen(reason) > 0)
    			{
    				formatex(msg[len], charsmax(msg) - len, " (%L: %s)", i, "REASON", reason);
    			}
    			show_activity_id(i, id, name, msg);
    		}
    	}

    	console_print(id, "[FPN] %L", id, "CLIENT_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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF | CMDTARGET_ONLY_ALIVE)
    	
    	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)

    	show_activity_key("ADMIN_SLAY_1", "ADMIN_SLAY_2", name, name2);

    	console_print(id, "[FPN] %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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF | CMDTARGET_ONLY_ALIVE)
    	
    	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)
    	
    	if(damage < 0)
    	{
    		console_print(id, "Nu poti da slap cu valori negative")
    		return PLUGIN_HANDLED;
    	}
    	
    	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)

    	show_activity_key("ADMIN_SLAP_1", "ADMIN_SLAP_2", name, name2, damage);

    	console_print(id, "[FPN] %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, "[FPN] %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)
    	
    	show_activity_key("ADMIN_MAP_1", "ADMIN_MAP_2", 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
    }

    stock bool:onlyRcon(const name[])
    {
    	new pentru=get_cvar_pointer(name);
    	if (pentru && get_pcvar_flags(pentru) & FCVAR_PROTECTED)
    	{
    		return true;
    	}
    	return false;
    }

    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)
    	
    	new pointer;
    	
    	if (equal(arg, "add") && (get_user_flags(id) & ADMIN_RCON))
    	{
    		if ((pointer=get_cvar_pointer(arg2))!=0)
    		{
    			new flags=get_pcvar_flags(pointer);
    			
    			if (!(flags & FCVAR_PROTECTED))
    			{
    				set_pcvar_flags(pointer,flags | FCVAR_PROTECTED);
    			}
    		}
    		return PLUGIN_HANDLED
    	}
    	
    	if ((pointer=get_cvar_pointer(arg))==0)
    	{
    		console_print(id, "[FPN] %L", id, "UNKNOWN_CVAR", arg)
    		return PLUGIN_HANDLED
    	}
    	
    	if (onlyRcon(arg) && !(get_user_flags(id) & ADMIN_RCON))
    	{
    		// Exception for the new onlyRcon rules:
    		//   sv_password is allowed to be modified by ADMIN_PASSWORD
    		if (!(equali(arg,"sv_password") && (get_user_flags(id) & ADMIN_PASSWORD)))
    		{
    			console_print(id, "[FPN] %L", id, "CVAR_NO_ACC")
    			return PLUGIN_HANDLED
    		}
    	}
    	
    	if (read_argc() < 3)
    	{
    		get_pcvar_string(pointer, arg2, 63)
    		console_print(id, "[FPN] %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)
    	
    	
    	// Display the message to all clients

    	new cvar_val[64];
    	new maxpl = get_maxplayers();
    	for (new i = 1; i <= maxpl; i++)
    	{
    		if (is_user_connected(i) && !is_user_bot(i))
    		{
    			if (get_pcvar_flags(pointer) & FCVAR_PROTECTED || equali(arg, "rcon_password"))
    			{
    				formatex(cvar_val, charsmax(cvar_val), "*** %L ***", i, "PROTECTED");
    			}
    			else
    			{
    				copy(cvar_val, charsmax(cvar_val), arg2);
    			}
    			show_activity_id(i, id, name, "%L", i, "SET_CVAR_TO", "", arg, cvar_val);
    		}
    	}

    	console_print(id, "[FPN] %L", id, "CVAR_CHANGED", arg, arg2)
    	
    	return PLUGIN_HANDLED
    }

    public cmdPlugins(id, level, cid)
    {
    	if (!cmd_access(id, level, cid, 1))
    		return PLUGIN_HANDLED
    		
    	if (id==0) // If server executes redirect this to "amxx plugins" for more in depth output
    	{
    		server_cmd("amxx plugins");
    		server_exec();
    		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 StartPLID=0;
    	new EndPLID;

    	new Temp[96]

    	new num = get_pluginsnum()
    	
    	if (read_argc() > 1)
    	{
    		read_argv(1,Temp,sizeof(Temp)-1);
    		StartPLID=str_to_num(Temp)-1; // zero-based
    	}

    	EndPLID=min(StartPLID + 10, num);
    	
    	new running = 0
    	
    	console_print(id, "----- %L -----", id, "LOADED_PLUGINS")
    	console_print(id, "%-18.17s %-11.10s %-17.16s %-16.15s %-9.8s", lName, lVersion, lAuthor, lFile, lStatus)

    	new i=StartPLID;
    	while (i <EndPLID)
    	{
    		get_plugin(i++, filename, 31, name, 31, version, 31, author, 31, status, 31)
    		console_print(id, "%-18.17s %-11.10s %-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", EndPLID-StartPLID, running)
    	console_print(id, "----- %L -----",id,"HELP_ENTRIES",StartPLID + 1,EndPLID,num);
    	
    	if (EndPLID < num)
    	{
    		formatex(Temp,sizeof(Temp)-1,"----- %L -----",id,"HELP_USE_MORE", EndPLID + 1);
    		replace_all(Temp,sizeof(Temp)-1,"amx_help","amx_plugins");
    		console_print(id,"%s",Temp);
    	}
    	else
    	{
    		formatex(Temp,sizeof(Temp)-1,"----- %L -----",id,"HELP_USE_BEGIN");
    		replace_all(Temp,sizeof(Temp)-1,"amx_help","amx_plugins");
    		console_print(id,"%s",Temp);
    	}

    	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], lStatus[32];

    	format(lName, 31, "%L", id, "NAME")
    	format(lVersion, 31, "%L", id, "VERSION")
    	format(lAuthor, 31, "%L", id, "AUTHOR")
    	format(lStatus, charsmax(lStatus), "%L", id, "STATUS")

    	new num = get_modulesnum()
    	
    	console_print(id, "%L:", id, "LOADED_MODULES")
    	console_print(id, "%-23.22s %-11.10s %-20.19s %-11.10s", lName, lVersion, lAuthor, lStatus)
    	
    	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, "bad load");
    				copy(name, charsmax(name), "unknown");
    				copy(author, charsmax(author), "unknown");
    				copy(version, charsmax(version), "unknown");
    			}
    		}
    		
    		console_print(id, "%-23.22s %-11.10s %-20.19s %-11.10s", name, version, author, sStatus)
    	}
    	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, "[FPN] %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, "[FPN] Executing file ^"%s^"", arg)
    	server_cmd("exec %s", arg)

    	show_activity_key("ADMIN_CONF_1", "ADMIN_CONF_2", name, 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, "[FPN] 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) 
    	if (pausable!=0)
    	{
    		g_pausAble = get_pcvar_float(pausable)
    	}
    	
    	if (!slayer)
    		slayer = find_player("h") 
    	
    	if (!slayer)
    	{ 
    		console_print(id, "[FPN] %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, "[FPN] %L", id, g_Paused ? "UNPAUSING" : "PAUSING")

    	// Display the message to all clients

    	new maxpl = get_maxplayers();
    	for (new i = 1; i <= maxpl; i++)
    	{
    		if (is_user_connected(i) && !is_user_bot(i))
    		{
    			show_activity_id(i, id, name, "%L server", i, g_Paused ? "UNPAUSE" : "PAUSE");
    		}
    	}

    	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_pcvar_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, "[FPN] %L", id, "COM_SENT_SERVER", arg)
    	server_cmd("%s", 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 %-20s %-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 %-20s %-8d %-6.5s %-6.5s %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 < 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, "[FPN] %L", id, "SKIP_MATCH", nick, ltags[ires])
    			continue
    		}
    		
    		if (get_user_flags(b) & ADMIN_IMMUNITY)
    		{
    			console_print(id, "[FPN] %L", id, "SKIP_IMM", nick)
    			continue
    		}
    		
    		console_print(id, "[FPN] %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, "[FPN] %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])

    	show_activity_key("ADMIN_LEAVE_1", "ADMIN_LEAVE_2", 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, CMDTARGET_OBEY_IMMUNITY | CMDTARGET_ALLOW_SELF)
    	
    	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)

    	show_activity_key("ADMIN_NICK_1", "ADMIN_NICK_2", name, name2, arg2);

    	console_print(id, "[FPN] %L", id, "CHANGED_NICK", name2, arg2)

    	return PLUGIN_HANDLED
    }

    public cmdLast(id, level, cid)
    {
    	if (!cmd_access(id, level, cid, 1))
    	{
    		return PLUGIN_HANDLED;
    	}
    	
    	new name[32];
    	new authid[32];
    	new ip[32];
    	new flags[32];
    	new access;
    	
    	
    	// This alignment is a bit weird (it should grow if the name is larger)
    	// but otherwise for the more common shorter name, it'll wrap in server console
    	// Steam client display is all skewed anyway because of the non fixed font.
    	console_print(id, "%19s %20s %15s %s", "name", "authid", "ip", "access");
    	
    	for (new i = 0; i < g_Size; i++)
    	{
    		GetInfo(i, name, charsmax(name), authid, charsmax(authid), ip, charsmax(ip), access);
    		
    		get_flags(access, flags, charsmax(flags));
    		
    		console_print(id, "%19s %20s %15s %s", name, authid, ip, flags);
    	}
    	
    	console_print(id, "%d old connections saved.", g_Size);
    	
    	return PLUGIN_HANDLED;
    }
public cmdNewBAN(id, level, cid)
{
   if (!cmd_access(id, level, cid, 2))
      return PLUGIN_HANDLED
   new target[32]
   
   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],admin_name[32], name2[32], authid2[32], name[32]
   new userid2 = get_user_userid(player)
   
   new motd[1501],len
   new sztime[54], Ip[32], hostname[64], szdata[54]
   
   get_user_authid(player, authid2, 31)
   get_user_authid(id, authid, 31)
   get_user_name(id, admin_name, 31)
   get_user_name(player, name2, 31)
   get_user_name(id, name, 31)
   
   get_time("%m.%d.%Y",szdata, 53)
   get_time("%H:%M:%S",sztime, 53)
   get_user_ip(player, Ip, 31, 1)
   get_cvar_string("hostname",hostname, 63)
   
   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(get_pcvar_num(player_ss) == 1 )
   {
      set_hudmessage(0, 255, 0, 0.39, 0.29, 0, 6.0, 10.0)
      show_hudmessage(id,"[ New Style Ban ] IP-ul tau: %s",Ip)
      
      client_print(player,print_chat,"** Sa executat comanda ^"%s^" asaupra ta!",command)
      client_print(player,print_chat,"** Numele tau: %s, IP-ul tau: %s, Banat de: %s, POSTEZI POZELE PE: %s",name2,Ip,admin_name,site)
      client_cmd(player,"spk ^"vox/bizwarn.screen.screen.screen^"") 
      client_cmd(player,"snapshot;%s;snapshot;%s;snapshot",gwait, gwait)
   }
   /********************************************************************************/
   if(get_pcvar_num(ban_show_chat) == 1 )
   {
      client_print(0,print_chat,"***ADMIN:%s la banat pe:%s Minute:^"%s^" Motiv:^"%s^"",admin_name,name2,minutes,reason)
   }
   /********************************************************************************/
   if(get_pcvar_num(logs) == 1 )
   {
      new szFile[128]
      get_configsdir(szFile,127)
      formatex(szFile,127,"%s/ban_logs.txt",szFile)
   
      if(!file_exists(szFile))
      {
         write_file(szFile,"Log'S Ban:",-1)
         write_file(szFile,"(c) PoSiTiOn Of PoWeR",-1)
         write_file(szFile," ",-1)
      }
      new szLog[256]
   
      formatex(szLog,255,"Admin: %s , la banat pe %s , in Data %s - Ora %s , Motiv: %s , Minute: %s ",admin_name,name2,szdata,sztime,reason,minutes)
      write_file(szFile,szLog,-1)
      write_file(szFile," ",-1)

   }
   /********************************************************************************/
   len = format(motd, 1500,"<body bgcolor=#000000><font color=#87cefa><pre>")
   len += format(motd[len], 1500-len,"<center><h4><font color=^"blue^">%s</font></h4><¢er>",hostname)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>DATA: %s - Ora: %s</B></color></left>^n",szdata,sztime)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Motiv: %s</B></color></left>^n",reason)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Ip: %s</B></color></left>^n",Ip)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Timp: %s minute</B></color></left>^n",minutes)
   len += format(motd[len], 1500-len,"<left><font color=^"red^"><B>Admin: %s </B></color></left>^n",admin_name)
   len += format(motd[len], 1500-len,"<left><font color=^"blue^">*pentru unban: postezi pozele pe %s</color></left>^n^n",site)
   show_motd(player,motd,msg_motd)
   /********************************************************************************/
   if (reason[0])
      set_task(9.0,"cmdban_reason",player)
   else
      set_task(10.0,"cmdban_no_reason",player)
   /********************************************************************************/
   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 < pnum; i++)
      {
         len = format(msg, 255, "%L", players, "ADMIN")
         
         if (activity == 1)
            len += copy(msg[len], 255-len, ":")
         else
            len += format(msg[len], 255-len, " %s:", name)
         
         len += format(msg[len], 255-len, " %L", players, "BAN")
         len += format(msg[len], 255-len, " %s ", name2)
      
         if (nNum)
            format(msg[len], 255-len, "%L", players, "FOR_MIN", minutes)
         else
            format(msg[len], 255-len, "%L", players, "PERM")
         
         client_print(players, print_chat, "%s", msg)
      }
   }
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip) 
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip) 
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip) 
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip)
   console_print(id,"[ New Style Ban ] NUME: %s - IP: %s",name2,Ip)
   console_print(id,"[AMXX] %L", id, "CLIENT_BANNED", name2)
   
   return PLUGIN_HANDLED
}

public cmdban_reason(player)
{
   new authid2[32],userid2
   
   userid2 = get_user_userid(player)
   
   get_user_authid(player, authid2, 31)
   
   new address[32],g_Reason[32]
   
   get_user_ip(player, address, 31, 1)
   
   new temp[64], banned[16], nNum
   
   nNum = str_to_num(minutes)
   
   copy(g_Reason, 31, reason)
   
   if (nNum)
      format(temp, 63, "%L", player, "FOR_MIN", minutes)
   else
      format(temp, 63, "%L", player, "PERM")
   
   format(banned, 15, "%L", player, "BANNED")
   
   server_cmd("kick #%d ^"%s (%s %s)^";wait;addip ^"%s^" ^"%s^";wait;writeip", userid2, g_Reason, banned, temp, minutes, address)
}

public cmdban_no_reason(player)
{
   new authid2[32], userid2, temp[64], banned[16], nNum
   
   userid2 = get_user_userid(player)
   
   get_user_authid(player, authid2, 31)
   
   new address[32]
   
   get_user_ip(player, address, 31, 1)
   
   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")
   
   server_cmd("kick #%d ^"%s %s^";wait;addip ^"%s^" ^"%s^";wait;writeip", userid2, banned, temp, minutes, address)
}

Code: Select all

"Daca ai culoare nu inseamna ca esti mai presus ca un utilizator. Culoare e un fel de "rasplata" pentru ca te implici in "ridicarea" acestei comunitati.
Unii nu realizeaza ca daca ai culoare nu inseamna ca esti smecher." -- by Alexey
:troll :troll

Spui ceva,dar faci altceva !
mr.f3lyx
Membru, skill +2
Membru, skill +2
Posts: 610
Joined: 10 Nov 2013, 20:24
Detinator Steam: Da
Location: Palermo, Italy
Has thanked: 69 times
Been thanked: 17 times

10 Feb 2014, 16:05

osal testez dar am omis sa zic ceva vreau ca comanda de ban sa fie aceasi cu cea clasica amx_ban
mr.f3lyx
Membru, skill +2
Membru, skill +2
Posts: 610
Joined: 10 Nov 2013, 20:24
Detinator Steam: Da
Location: Palermo, Italy
Has thanked: 69 times
Been thanked: 17 times

25 Mar 2014, 12:24

Daca se poate sa-mi modifici si mie asta sa-mi apara in consola ceva de genul
client_print ( player , print_console , "======================" ) ;
client_print ( player , print_console , "**| Motivul : %s |**", reason ) ;
client_print ( player , print_console , "**| Durata ( 0 = permanent ) : %s |**" , minutes ) ;
client_print ( player , print_console , "**| Adminul: %s |**", name ) ;
client_print ( player , print_console , "======================" ) ;

cand cineva ia ban sai arat de la cine durata motivul
sma | Afiseaza codul
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)

log_amx("Ban: ^"%s<%d><%s><>^" ban si kick ^"%s<%d><%s><>^" (minute ^"%s^") (motiv ^"%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 pl[32];
get_user_name(player, pl, 31)

FpNChaT(0, ".e[.vFPN.e].v %s .ga fost banat timp de .v%s .gminute. .eMotiv:.v %s.", pl, minutes, reason)
client_cmd(player, "wait;snapshot;wait")


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 < pnum; i++)
{
len = format(msg, 255, "%L", players, "ADMIN")

if (activity == 1)
len += copy(msg[len], 255-len, ":")
else
len += format(msg[len], 255-len, " %s:", name)

len += format(msg[len], 255-len, " %L", players, "BAN")
len += format(msg[len], 255-len, " %s ", name2)

if (nNum)
format(msg[len], 255-len, "%L", players, "FOR_MIN", minutes)
else
format(msg[len], 255-len, "%L", players, "PERM")

client_print(players, print_chat, "%s", msg)
}
}
console_print(id, "%L", id, "CLIENT_BANNED", name2)

return PLUGIN_HANDLED
}


Multumesc anticipat ! ^:)^
User avatar
h4wk
Fost moderator
Fost moderator
Posts: 3806
Joined: 22 Sep 2009, 13:10
Detinator Steam: Da
Reputatie: Fost eXtream Mod
Nume anterior : DaZ , zimpe , Dan eXtream
Location: Iasi
Has thanked: 306 times
Been thanked: 321 times
Contact:

25 Mar 2014, 14:36

| Afiseaza codul
public cmdBan(id, level, cid)
{
        if(!cmd_access(id, level, cid, 3))
	    return PLUGIN_HANDLED
	
        new Target[32], Minutes[8], Reason[32]

        read_argv(1, Target, 31)
        read_argv(2, Minutes, 7)
        read_argv(3, Reason, 31)

        new player = cmd_target(id, Target, 9)
	
        if(!player)
	    return PLUGIN_HANDLED

        static Aname[32], Pname[32]

        new usrip[32]
        new userid2 = get_user_userid(player)

        get_user_name(id, Aname, 31)	
        get_user_name(player, Pname, 31)
        get_user_ip(player, usrip, 31, 1)

        new Temp[64], Banned[16], nNum = str_to_num(Minutes)

        if(nNum)
            format(Temp, 63, " pentru %s minute", Minutes)
        else
        {
            console_print(id, "[AMXX]Timpul minim care poate fi folosit este: 1 minut!")
            return PLUGIN_HANDLED
        }
        format(Banned, 15, "Banned ", player)

        if(!nNum)
        { 
            console_print(id, "[AMXX]Timpul minim care poate fi folosit este: 1 minut!")
            return PLUGIN_HANDLED
        }
        if(Reason[0])
        {
            server_cmd("kick #%d ^"%s %s . Motiv: %s^";wait;addip ^"%s^" ^"%s^";wait;writeip", userid2, Banned, Temp, Reason, Minutes, usrip)
        }
        else
        {
	    console_print(id, "[AMXX]Ai nevoie de un motiv dupa timp, exemplu: amx_tban x 1 cheater (unde cheater e motivul)")
            return PLUGIN_HANDLED
        }

	client_print(0, print_chat, "* %s foloseste comanda: ban %s pentru %s minut(e). (motiv: ^"%s^")", Aname, Pname, Minutes, Reason)
	console_print(id, "======================")
	console_print(id, "Motiv : %s ", Reason)
	console_print(id, "Durata : %s ", Minutes)
	console_print(id, "Admin : %s ", Aname)
	console_print(id, "======================")  
	
	return PLUGIN_HANDLED
}

Code: Select all

"Daca ai culoare nu inseamna ca esti mai presus ca un utilizator. Culoare e un fel de "rasplata" pentru ca te implici in "ridicarea" acestei comunitati.
Unii nu realizeaza ca daca ai culoare nu inseamna ca esti smecher." -- by Alexey
:troll :troll

Spui ceva,dar faci altceva !
mr.f3lyx
Membru, skill +2
Membru, skill +2
Posts: 610
Joined: 10 Nov 2013, 20:24
Detinator Steam: Da
Location: Palermo, Italy
Has thanked: 69 times
Been thanked: 17 times

25 Mar 2014, 17:58

rezolvat
Post Reply

Return to “Modificari pluginuri”

  • Information
  • Who is online

    Users browsing this forum: No registered users and 13 guests