#include <amxmodx>
#define PLUGIN "Ban Vote"
#define VERSION "1.0"
#define AUTHOR "Alka"
#define BAN_VOTE_DELAY 60.0
new g_iMaxPlayers;
new g_iVotesNum;
new g_szVoterName[32];
new g_szVotedName[32];
new g_szReason[64];
new bool:g_bValidUid;
new Float:g_fLastVote;
new bool:g_bHasVoted[33];
new const g_szSyntax[] = "/vote";
new const g_szBanTime[] = "1440";
public plugin_init() {
register_plugin(PLUGIN, VERSION, AUTHOR);
register_clcmd("say", "clcmdHandleSay", -1, "");
register_clcmd("enter_ban_reason", "clcmdBanReason", -1, "");
g_iMaxPlayers = get_maxplayers();
}
public clcmdHandleSay(id)
{
new szArgs[128];
read_args(szArgs, sizeof szArgs - 1);
remove_quotes(szArgs);
if(equali(szArgs, g_szSyntax))
{
Util_DisplayList(id);
return 0;
}
new szTemp[32];
parse(szArgs, szArgs, sizeof szArgs - 1, szTemp, sizeof szTemp - 1);
if(equali(szArgs, g_szSyntax) && szTemp[0] == '#')
{
new iPlayers[32], iPlayersNum;
get_players(iPlayers, iPlayersNum, "ch");
if(iPlayersNum < 3)
{
Util_PrintGreen(id, "> Sorry, not enough players(3) to start a Ban Vote!");
return 1;
}
if((get_gametime() - g_fLastVote) < BAN_VOTE_DELAY)
{
Util_PrintGreen(id, "> Sorry, you must wait %.1f sec. before start another vote!", BAN_VOTE_DELAY);
return 1;
}
for(new i = 0 ; i < sizeof szTemp ; i++)
{
if(!isdigit(szTemp[i]) && szTemp[i] != '#' && szTemp[i])
{
Util_PrintGreen(id, "> Syntax Error: Invalid userid! Type ^"/vote^" for more info.");
return 1;
}
}
for(new j = 1 ; j <= g_iMaxPlayers ; j++)
{
if(!is_user_connected(j))
continue;
if(get_user_userid(j) == str_to_num(szTemp[1]))
{
g_bValidUid = true;
get_user_name(id, g_szVoterName, sizeof g_szVoterName - 1);
get_user_name(j, g_szVotedName, sizeof g_szVotedName - 1);
Util_PrintGreen(0, "> Player '%s' voted '%s' to be banned!", g_szVoterName, g_szVotedName);
Util_PrintGreen(id, "> Enter the ban reason!");
g_bHasVoted[id] = true;
client_cmd(id, "messagemode enter_ban_reason");
}
}
if(!g_bValidUid)
{
Util_PrintGreen(id, "> Syntax Error: Invalid userid! Type ^"/vote^" for more info.");
return 1;
}
}
g_fLastVote = get_gametime();
return 0;
}
public clcmdBanReason(id)
{
if(!g_bHasVoted[id])
return 1;
read_argv(1, g_szReason, sizeof g_szReason - 1);
if(!g_szReason[0])
{
client_cmd(id, "messagemode enter_ban_reason");
return 1;
}
g_bValidUid = false;
g_bHasVoted[id] = false;
new szTemp[128];
formatex(szTemp, sizeof szTemp - 1, "wBan r%s wfor: y%s", g_szVotedName, g_szReason);
new iMenu = menu_create(szTemp, "menuHandle", 0);
menu_additem(iMenu, "wYes", "1", 0, -1);
menu_additem(iMenu, "wNo", "2", 0, -1);
menu_addblank(iMenu, 0);
menu_setprop(iMenu, MPROP_EXIT, MEXIT_NEVER);
for(new i = 1 ; i <= g_iMaxPlayers ; i++)
{
if(!is_user_connected(i) || (i == get_user_index(g_szVotedName)))
continue;
menu_display(i, iMenu, 0);
}
set_task(15.0, "taskCheckVotes", 0);
return 1;
}
public menuHandle(id, menu, item)
{
new szData[6], iAccess, iCallBack;
menu_item_getinfo(menu, item, iAccess, szData, sizeof szData - 1, _, _, iCallBack);
new iKey = str_to_num(szData);
switch(iKey)
{
case 1 : { g_iVotesNum++; }
}
return 1;
}
public taskCheckVotes()
{
new iPlayers[32], iPlayersNum;
get_players(iPlayers, iPlayersNum, "ch");
if(g_iVotesNum >= (iPlayersNum - 1))
{
new id = get_user_index(g_szVotedName);
if(!is_user_connected(id))
{
Util_PrintGreen(0, "> Ban vote has failed, since player is not on server anymore!");
}
else
{
if(!is_steam_user(id))
{
new szIp[32];
get_user_ip(id, szIp, sizeof szIp - 1, 1);
server_cmd("kick #%d ^"Ban Vote^";wait;addip ^"%s^" ^"%s^";wait;writeip", get_user_userid(id), g_szBanTime, szIp);
}
else
{
new szSteamId[32];
get_user_authid(id, szSteamId, sizeof szSteamId - 1);
server_cmd("kick #%d ^"Ban Vote^";wait;banid ^"%s^" ^"%s^";wait;writeid", get_user_userid(id), g_szBanTime, szSteamId);
}
Util_PrintGreen(0, "> Player '%s' has been successfully banned due Ban Vote!", g_szVotedName);
Util_Log("Player '%s' has been banned due Ban Vote started by '%s'!Reason: '%s'", g_szVotedName, g_szVoterName, g_szReason);
}
}
g_iVotesNum = 0;
g_szVotedName[0] = '^0';
g_szVoterName[0] = '^0';
g_szReason[0] = '^0';
}
public client_disconnect(id)
{
static iVoted;
iVoted = get_user_index(g_szVotedName);
if(id == iVoted)
{
if(!is_steam_user(id))
{
new szIp[32];
get_user_ip(id, szIp, sizeof szIp - 1, 1);
server_cmd("kick #%d ^"Ban Vote^";wait;addip ^"1440^" ^"%s^";wait;writeip", get_user_userid(id), szIp);
}
else
{
new szSteamId[32];
get_user_authid(id, szSteamId, sizeof szSteamId - 1);
server_cmd("kick #%d ^"Ban Vote^";wait;banid ^"1440^" ^"%s^";wait;writeid", get_user_userid(id), szSteamId);
}
Util_PrintGreen(0, "> Player '%s' has been successfully banned due leaving the server in middle of a Ban Vote!", g_szVotedName);
Util_Log("Player '%s' has been successfully banned due leaving the server in middle of a Ban Vote!", g_szVotedName);
}
}
stock Util_DisplayList(id)
{
new szBuffer[512], iLen;
new szName[32], iIndex;
iLen = formatex(szBuffer, sizeof szBuffer - 1, "<body bgcolor=#000000><font color=#ff0000><pre>");
iLen += formatex(szBuffer[iLen], (sizeof szBuffer - 1) - iLen, "<font size=^"4^">%s %s %s</font>^n", "#", "Name", "Steam User");
for(new i = 1 ; i <= g_iMaxPlayers ; i++)
{
if(!is_user_connected(i))
continue;
get_user_name(i, szName, sizeof szName - 1);
iIndex = get_user_userid(i);
iLen += formatex(szBuffer[iLen], (sizeof szBuffer - 1) - iLen, "%d %s %s^n", iIndex, szName, is_steam_user(i) ? "Yes" : "No");
}
show_motd(id, szBuffer, "");
}
stock bool:is_steam_user(id)
{
new szSteamid[32];
get_user_authid(id, szSteamid, sizeof szSteamid - 1);
if(szSteamid[7] == ':')
return true;
return false;
}
stock Util_PrintGreen(id, const message[], {Float, Sql, Resul,_}:...) {
static msg[192];
msg[0] = 0x04;
vformat(msg[1], 190, message, 3);
if( id > 0 && id <= g_iMaxPlayers)
{
message_begin(MSG_ONE, get_user_msgid("SayText"),_, id);
write_byte(id);
write_string(msg);
message_end();
}
else if(id == 0)
{
for( new i = 1; i <= g_iMaxPlayers; i++ )
{
if(!is_user_connected(i))
continue;
message_begin(MSG_ONE, get_user_msgid("SayText"),_, i);
write_byte(i);
write_string(msg);
message_end();
}
}
}
stock Util_Log(const string[], {Float, Sql, Resul,_}:...) {
static const szFile[] = "vote_ban.log";
static szMessage[256];
vformat(szMessage, sizeof szMessage - 1, string, 3);
log_to_file(szFile, szMessage);
}
Witamy w Nieoficjalnym polskim support'cie AMX Mod X
Witamy w Nieoficjalnym polskim support'cie AMX Mod X, jak w większości społeczności internetowych musisz się zarejestrować aby móc odpowiadać lub zakładać nowe tematy, ale nie bój się to jest prosty proces w którym wymagamy minimalnych informacji.
|
Guest Message by DevFuse
Vote Ban - Banconfig ?
Temat rozp. luk, 30.08.2009 20:36
2 odpowiedzi w tym temacie
#1
Napisano 30.08.2009 20:36
Czy jest możliwości przerobić plugin, aby dawał bany na amx_banconfig a nie na IP, bo co do ban na steam to może zostać ?
#2
Napisano 31.08.2009 20:30
No i musisz mieć plugin z komendą amx_bancfg
Załączone pliki
#3
Napisano 01.09.2009 10:38
Tutaj daje lepszy plugin:
http://forums.allied...ead.php?t=43568
Problemy:
1. Nie ma logów w osobnym pliku, typu: kto wpisał /voteban, kto dostał bana, IP, data.
2. Gdy ustawine jest
3. Przerobiłem linijke
na
Gdy ktos dostaje bana nadal gra
http://forums.allied...ead.php?t=43568
#include <amxmodx>
#include <amxmisc>
#define MAX_players 32
#define MAX_menudata 1024
new ga_PlayerName[MAX_players][32]
new ga_PlayerAuthID[MAX_players][35]
new ga_PlayerID[MAX_players]
new ga_PlayerIP[MAX_players][16]
new ga_MenuData[MAX_menudata]
new ga_Choice[2]
new gi_VoteStarter
new gi_MenuPosition
new gi_Sellection
new gi_TotalPlayers
new gi_SysTimeOffset = 0
new i
//pcvars
new gi_LastTime
new gi_DelayTime
new gf_Ratio
new gf_MinVoters
new gf_BF_Ratio
new gi_BanTime
new gi_Disable
new gi_BanType
public plugin_init()
{
register_plugin("voteban menu","1.2","hjvl")
register_clcmd("say /voteban","SayIt" )
register_menucmd(register_menuid("ChoosePlayer"), 1023, "ChooseMenu")
register_menucmd(register_menuid("VoteMenu"), 1023, "CountVotes")
gi_LastTime=register_cvar("amx_voteban_lasttime","0")
gi_DelayTime=register_cvar("amxx_voteban_delaytime","600")
gf_Ratio=register_cvar("amxx_voteban_ratio","0.50")
gf_MinVoters=register_cvar("amxx_voteban_minvoters","0.0")
gf_BF_Ratio=register_cvar("amxx_voteban_bf_ratio","0.0")
gi_BanTime=register_cvar("amxx_voteban_bantime","5")
gi_Disable=register_cvar("amxx_voteban_disable","0")
gi_BanType=register_cvar("amxx_voteban_type","0")
}
public SayIt(id)
{
if(get_pcvar_num(gi_Disable))
{
client_print(id,print_chat,"[AMXX]amx_votaban disabled")
return 0
}
new Elapsed=get_systime(gi_SysTimeOffset) - get_pcvar_num(gi_LastTime)
new Delay=get_pcvar_num(gi_DelayTime)
if( (Delay > Elapsed) && !is_user_admin(id) )
{
new seconds = Delay - Elapsed
client_print(id,print_chat,"[AMXX] You have to wait %d seconds before a new voteban can be started", seconds)
return 0
}
get_players( ga_PlayerID, gi_TotalPlayers )
for(i=0; i<gi_TotalPlayers; i++)
{
new TempID = ga_PlayerID[i]
if( is_user_admin(TempID))
{
if(!is_user_admin(id))
{
client_print(id,print_chat,"There is an admin on the server, voting is disabled!")
return 0
}
}
if(TempID == id)
gi_VoteStarter=i
get_user_name( TempID, ga_PlayerName[i], 31 )
get_user_authid( TempID, ga_PlayerAuthID[i], 34 )
get_user_ip( TempID, ga_PlayerIP[i], 15, 1 )
}
gi_MenuPosition = 0
ShowPlayerMenu(id)
return 0
}
public ShowPlayerMenu(id)
{
new arrayloc = 0
new keys = (1<<9)
arrayloc = format(ga_MenuData,(MAX_menudata-1),"voteban menu ^n")
for(i=0; i<8; i++)
if( gi_TotalPlayers>(gi_MenuPosition+i) )
{
arrayloc += format(ga_MenuData[arrayloc],(MAX_menudata-1-arrayloc),"%d. %s^n", i+1, ga_PlayerName[gi_MenuPosition+i])
keys |= (1<<i)
}
if( gi_TotalPlayers>(gi_MenuPosition+8) )
{
arrayloc += format(ga_MenuData[arrayloc],(MAX_menudata-1-arrayloc),"^n9. More")
keys |= (1<<8)
}
arrayloc += format(ga_MenuData[arrayloc],(MAX_menudata-1-arrayloc),"^n0. Back/exit")
show_menu(id, keys, ga_MenuData, 20, "ChoosePlayer")
return PLUGIN_HANDLED
}
public ChooseMenu(id, key)
{
switch(key)
{
case 8:
{
gi_MenuPosition=gi_MenuPosition+8
ShowPlayerMenu(id)
}
case 9:
{
if(gi_MenuPosition>=8)
{
gi_MenuPosition=gi_MenuPosition-8
ShowPlayerMenu(id)
}
else
return 0
}
default:
{
gi_Sellection=gi_MenuPosition+key
new Now=get_systime(gi_SysTimeOffset)
set_pcvar_num(gi_LastTime, Now)
run_vote()
return 0
}
}
return PLUGIN_HANDLED
}
public run_vote()
{
log_amx("Vote ban started by %s for %s %s", ga_PlayerName[gi_VoteStarter], ga_PlayerName[gi_Sellection], ga_PlayerAuthID[gi_Sellection])
format(ga_MenuData,(MAX_menudata-1),"Ban %s for %d minutes?^n1. Yes^n2. No",ga_PlayerName[gi_Sellection], get_pcvar_num(gi_BanTime))
ga_Choice[0] = 0
ga_Choice[1] = 0
show_menu( 0, (1<<0)|(1<<1), ga_MenuData, 15, "VoteMenu" )
set_task(15.0,"outcom")
return 0
}
public CountVotes(id, key)
{
++ga_Choice[key]
return PLUGIN_HANDLED
}
public outcom()
{
new TotalVotes = ga_Choice[0] + ga_Choice[1]
new Float:result = (float(ga_Choice[0]) / float(TotalVotes))
if( get_pcvar_float(gf_MinVoters) >= ( float(TotalVotes) / float(gi_TotalPlayers) ) )
{
client_print(0,print_chat,"[AMXX] Not enough voters to ban %s!", ga_PlayerName[gi_Sellection])
return 0
}
else
{
if( result < get_pcvar_float(gf_BF_Ratio) )
{
client_print(0,print_chat,"[AMXX] The vote back fired at %s, he is banned for %d minutes", ga_PlayerName[gi_VoteStarter], get_pcvar_num(gi_BanTime))
ActualBan(gi_VoteStarter)
log_amx("[AMXX] The vote back fired at %s, he is banned for %d minutes", ga_PlayerName[gi_VoteStarter], get_pcvar_num(gi_BanTime))
}
if( result >= get_pcvar_float(gf_Ratio) )
{
client_print(0,print_chat,"[AMXX] The vote succeeded, %s is banned for %d minutes", ga_PlayerName[gi_Sellection], get_pcvar_num(gi_BanTime))
log_amx("[AMXX] The vote succeeded: %s is banned for %d minutes", ga_PlayerAuthID[gi_Sellection], get_pcvar_num(gi_BanTime))
ActualBan(gi_Sellection)
}
else
{
client_print(0,print_chat,"[AMXX] The vote did not succeeded!")
log_amx("[AMXX] The voteban dit not sucseed.")
}
}
client_print(0,print_chat,"A total of %d players, %d voted yes.", gi_TotalPlayers, ga_Choice[0])
return 0
}
public ActualBan(Selected)
{
new Type = get_pcvar_num(gi_BanType)
switch(Type)
{
case 1:
server_cmd("addip %d %s", get_pcvar_num(gi_BanTime), ga_PlayerIP[Selected])
case 2:
server_cmd("amx_ban %d %s Voteban", get_pcvar_num(gi_BanTime), ga_PlayerAuthID[Selected])
default:
server_cmd("banid %d %s kick", get_pcvar_num(gi_BanTime), ga_PlayerAuthID[Selected])
}
return 0
} Problemy:
1. Nie ma logów w osobnym pliku, typu: kto wpisał /voteban, kto dostał bana, IP, data.
2. Gdy ustawine jest
gf_Ratio=register_cvar("amxx_voteban_ratio","0.50")przy glosowaniu 18 osób 6 było za i głosownie zakończone sukcesem.3. Przerobiłem linijke
server_cmd("amx_ban %d %s Voteban", get_pcvar_num(gi_BanTime), ga_PlayerAuthID[Selected])na
server_cmd("amx_banconfig %d %s Voteban", get_pcvar_num(gi_BanTime), ga_PlayerAuthID[Selected])Gdy ktos dostaje bana nadal gra
Użytkownicy przeglądający ten temat: 0
0 użytkowników, 0 gości, 0 anonimowych


Dodatki SourceMod



Temat jest zamknięty


shit.amxx






