Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- /*
- * Simple Votekick & Voteban System by DJ Deagle
- */
- #define FILTERSCRIPT
- #include a_samp
- #include ocmd
- new yes,no,active,did[MAX_PLAYERS],sendername[MAX_PLAYER_NAME],usedname[MAX_PLAYER_NAME];
- forward EndVote(target);
- #if defined FILTERSCRIPT
- public OnFilterScriptInit()
- {
- print("\n--------------------------------------");
- print(" Simple Votekick & Voteban System by DJ Deagle! ");
- print("--------------------------------------\n");
- yes = 0; no = 0; active = 0;
- return 1;
- }
- #endif
- public OnPlayerRequestClass(playerid, classid)
- {
- SetPlayerPos(playerid, 1958.3783, 1343.1572, 15.3746);
- SetPlayerCameraPos(playerid, 1958.3783, 1343.1572, 15.3746);
- SetPlayerCameraLookAt(playerid, 1958.3783, 1343.1572, 15.3746);
- return 1;
- }
- public OnPlayerConnect(playerid)
- {
- did[playerid] = 0;
- return 1;
- }
- public OnPlayerDisconnect(playerid, reason)
- {
- did[playerid] = 0;
- return 1;
- }
- public OnPlayerSpawn(playerid)
- {
- return 1;
- }
- public OnPlayerDeath(playerid, killerid, reason)
- {
- return 1;
- }
- public OnVehicleSpawn(vehicleid)
- {
- return 1;
- }
- public OnVehicleDeath(vehicleid, killerid)
- {
- return 1;
- }
- public OnPlayerText(playerid, text[])
- {
- return 1;
- }
- public OnPlayerCommandText(playerid, cmdtext[])
- {
- return 1;
- }
- public OnPlayerEnterVehicle(playerid, vehicleid, ispassenger)
- {
- return 1;
- }
- public OnPlayerExitVehicle(playerid, vehicleid)
- {
- return 1;
- }
- public OnPlayerStateChange(playerid, newstate, oldstate)
- {
- return 1;
- }
- public OnPlayerEnterCheckpoint(playerid)
- {
- return 1;
- }
- public OnPlayerLeaveCheckpoint(playerid)
- {
- return 1;
- }
- public OnPlayerEnterRaceCheckpoint(playerid)
- {
- return 1;
- }
- public OnPlayerLeaveRaceCheckpoint(playerid)
- {
- return 1;
- }
- public OnRconCommand(cmd[])
- {
- return 1;
- }
- public OnPlayerRequestSpawn(playerid)
- {
- return 1;
- }
- public OnObjectMoved(objectid)
- {
- return 1;
- }
- public OnPlayerObjectMoved(playerid, objectid)
- {
- return 1;
- }
- public OnPlayerPickUpPickup(playerid, pickupid)
- {
- return 1;
- }
- public OnVehicleMod(playerid, vehicleid, componentid)
- {
- return 1;
- }
- public OnVehiclePaintjob(playerid, vehicleid, paintjobid)
- {
- return 1;
- }
- public OnVehicleRespray(playerid, vehicleid, color1, color2)
- {
- return 1;
- }
- public OnPlayerSelectedMenuRow(playerid, row)
- {
- return 1;
- }
- public OnPlayerExitedMenu(playerid)
- {
- return 1;
- }
- public OnPlayerInteriorChange(playerid, newinteriorid, oldinteriorid)
- {
- return 1;
- }
- public OnPlayerKeyStateChange(playerid, newkeys, oldkeys)
- {
- return 1;
- }
- public OnRconLoginAttempt(ip[], password[], success)
- {
- return 1;
- }
- public OnPlayerUpdate(playerid)
- {
- return 1;
- }
- public OnPlayerStreamIn(playerid, forplayerid)
- {
- return 1;
- }
- public OnPlayerStreamOut(playerid, forplayerid)
- {
- return 1;
- }
- public OnVehicleStreamIn(vehicleid, forplayerid)
- {
- return 1;
- }
- public OnVehicleStreamOut(vehicleid, forplayerid)
- {
- return 1;
- }
- public OnDialogResponse(playerid, dialogid, response, listitem, inputtext[])
- {
- return 1;
- }
- public OnPlayerClickPlayer(playerid, clickedplayerid, source)
- {
- return 1;
- }
- ocmd:votekick(playerid,params[])
- {
- new pID,string[128];
- if(active != 0)return SendClientMessage(playerid,-1,"Es ist bereits ein Votekick oder Voteban aktiv, warte bis dieser abgelaufen ist!");
- if(sscanf(params,"us",pID,string))return SendClientMessage(playerid,-1,"Benutze: /votekick [Spieler-ID] [Grund]");
- GetPlayerName(playerid,sendername,sizeof sendername);
- GetPlayerName(pID,usedname,sizeof usedname);
- active = 1; yes ++; did[playerid] = 1;
- format(string,sizeof string,"Der Spieler %s möchte den Spieler %s via Votekick vom Server kicken! Grund: %s",sendername,usedname,string);
- SendClientMessageToAll(-1," ");
- SendClientMessageToAll(-1,string);
- SendClientMessageToAll(-1,"Um zu voten gebe nun /yes oder /no ein!");
- SendClientMessageToAll(-1,"Dafür hast du 13 Sekunden Zeit.");
- SetTimerEx("EndVote",13000,0,"d",pID);
- return 1;
- }
- ocmd:voteban(playerid,params[])
- {
- new pID,string[128];
- if(active != 0)return SendClientMessage(playerid,-1,"Es ist bereits ein Votekick oder Voteban aktiv, warte bis dieser abgelaufen ist!");
- if(sscanf(params,"us",pID,string))return SendClientMessage(playerid,-1,"Benutze: /voteban [Spieler-ID] [Grund]");
- GetPlayerName(playerid,sendername,sizeof sendername);
- GetPlayerName(pID,usedname,sizeof usedname);
- active = 2; yes ++; did[playerid] = 1;
- format(string,sizeof string,"Der Spieler %s möchte den Spieler %s via Voteban vom Server bannen! Grund: %s",sendername,usedname,string);
- SendClientMessageToAll(-1," ");
- SendClientMessageToAll(-1,string);
- SendClientMessageToAll(-1,"Um zu voten gebe nun /yes oder /no ein!");
- SendClientMessageToAll(-1,"Dafür hast du 13 Sekunden Zeit.");
- SetTimerEx("EndVote",13000,0,"d",pID);
- return 1;
- }
- ocmd:yes(playerid,params[])
- {
- if(did[playerid] == 1)return SendClientMessage(playerid,-1,"Du kannst nur ein mal Voten!");
- if(active == 0)return SendClientMessage(playerid,-1,"Es ist kein Votekick oder Voteban aktiv!");
- yes ++; did[playerid] = 1;
- SendClientMessage(playerid,-1,"Du hast für Ja gevotet.");
- return 1;
- }
- ocmd:no(playerid,params[])
- {
- if(did[playerid] == 1)return SendClientMessage(playerid,-1,"Du kannst nur ein mal Voten!");
- if(active == 0)return SendClientMessage(playerid,-1,"Es ist kein Votekick oder Voteban aktiv!");
- no ++; did[playerid] = 1;
- SendClientMessage(playerid,-1,"Du hast für Nein gevotet.");
- return 1;
- }
- public EndVote(target)
- {
- new string[128];
- SendClientMessageToAll(-1,"Die Abstimmung wurde beendet und die Stimmen werden sortiert!");
- SendClientMessageToAll(-1," ");
- if(yes > no){
- if(active == 1) {
- GetPlayerName(target,sendername,sizeof sendername);
- Kick(target);
- format(string,sizeof string,"Es haben %d Spieler für Ja, und %d Spieler für Nein gestimmt!",yes,no);
- SendClientMessageToAll(-1,string);
- format(string,sizeof string,"Der Spieler %s wurde vom Server gekickt!",sendername);
- SendClientMessageToAll(-1,string);
- active = 0; yes = 0; no = 0;
- }
- if(active == 2) {
- GetPlayerName(target,sendername,sizeof sendername);
- Ban(target);
- format(string,sizeof string,"Es haben %d Spieler für Ja, und %d Spieler für Nein gestimmt!",yes,no);
- SendClientMessageToAll(-1,string);
- format(string,sizeof string,"Der Spieler %s wurde vom Server gebannt!",sendername);
- SendClientMessageToAll(-1,string);
- active = 0; yes = 0; no = 0;
- }
- }
- if(no > yes){
- if(active == 1) {
- GetPlayerName(target,sendername,sizeof sendername);
- format(string,sizeof string,"Es haben %d Spieler für Ja, und %d Spieler für Nein gestimmt!",yes,no);
- SendClientMessageToAll(-1,string);
- format(string,sizeof string,"Der Spieler %s wurde nicht vom Server gekickt!",sendername);
- SendClientMessageToAll(-1,string);
- active = 0; yes = 0; no = 0;
- }
- if(active == 2) {
- GetPlayerName(target,sendername,sizeof sendername);
- format(string,sizeof string,"Es haben %d Spieler für Ja, und %d Spieler für Nein gestimmt!",yes,no);
- SendClientMessageToAll(-1,string);
- format(string,sizeof string,"Der Spieler %s wurde nicht vom Server gebannt!",sendername);
- SendClientMessageToAll(-1,string);
- active = 0; yes = 0; no = 0;
- }
- }
- if(yes == no){
- if(active == 1) {
- GetPlayerName(target,sendername,sizeof sendername);
- format(string,sizeof string,"Es haben %d Spieler für Ja, und %d Spieler für Nein gestimmt!",yes,no);
- SendClientMessageToAll(-1,string);
- format(string,sizeof string,"Der Spieler %s wurde nicht vom Server gekickt!",sendername);
- SendClientMessageToAll(-1,string);
- active = 0; yes = 0; no = 0;
- }
- if(active == 2) {
- GetPlayerName(target,sendername,sizeof sendername);
- format(string,sizeof string,"Es haben %d Spieler für Ja, und %d Spieler für Nein gestimmt!",yes,no);
- SendClientMessageToAll(-1,string);
- format(string,sizeof string,"Der Spieler %s wurde nicht vom Server gebannt!",sendername);
- SendClientMessageToAll(-1,string);
- active = 0; yes = 0; no = 0;
- }
- }
- for(new i;i<MAX_PLAYERS;i++) {
- if(IsPlayerConnected(i) && did[i] == 1) {
- did[i] = 0;
- }
- }
- return 1;
- }
- stock sscanf(string[], format[], {Float,_}:...)
- {
- #if defined isnull
- if (isnull(string))
- #else
- if (string[0] == 0 || (string[0] == 1 && string[1] == 0))
- #endif
- {
- return format[0];
- }
- #pragma tabsize 4
- new
- formatPos = 0,
- stringPos = 0,
- paramPos = 2,
- paramCount = numargs(),
- delim = ' ';
- while (string[stringPos] && string[stringPos] <= ' ')
- {
- stringPos++;
- }
- while (paramPos < paramCount && string[stringPos])
- {
- switch (format[formatPos++])
- {
- case '\0':
- {
- return 0;
- }
- case 'i', 'd':
- {
- new
- neg = 1,
- num = 0,
- ch = string[stringPos];
- if (ch == '-')
- {
- neg = -1;
- ch = string[++stringPos];
- }
- do
- {
- stringPos++;
- if ('0' <= ch <= '9')
- {
- num = (num * 10) + (ch - '0');
- }
- else
- {
- return -1;
- }
- }
- while ((ch = string[stringPos]) > ' ' && ch != delim);
- setarg(paramPos, 0, num * neg);
- }
- case 'h', 'x':
- {
- new
- num = 0,
- ch = string[stringPos];
- do
- {
- stringPos++;
- switch (ch)
- {
- case 'x', 'X':
- {
- num = 0;
- continue;
- }
- case '0' .. '9':
- {
- num = (num << 4) | (ch - '0');
- }
- case 'a' .. 'f':
- {
- num = (num << 4) | (ch - ('a' - 10));
- }
- case 'A' .. 'F':
- {
- num = (num << 4) | (ch - ('A' - 10));
- }
- default:
- {
- return -1;
- }
- }
- }
- while ((ch = string[stringPos]) > ' ' && ch != delim);
- setarg(paramPos, 0, num);
- }
- case 'c':
- {
- setarg(paramPos, 0, string[stringPos++]);
- }
- case 'f':
- {
- new changestr[16], changepos = 0, strpos = stringPos;
- while(changepos < 16 && string[strpos] && string[strpos] != delim)
- {
- changestr[changepos++] = string[strpos++];
- }
- changestr[changepos] = '\0';
- setarg(paramPos,0,_:floatstr(changestr));
- }
- case 'p':
- {
- delim = format[formatPos++];
- continue;
- }
- case '\'':
- {
- new
- end = formatPos - 1,
- ch;
- while ((ch = format[++end]) && ch != '\'') {}
- if (!ch)
- {
- return -1;
- }
- format[end] = '\0';
- if ((ch = strfind(string, format[formatPos], false, stringPos)) == -1)
- {
- if (format[end + 1])
- {
- return -1;
- }
- return 0;
- }
- format[end] = '\'';
- stringPos = ch + (end - formatPos);
- formatPos = end + 1;
- }
- case 'u':
- {
- new
- end = stringPos - 1,
- id = 0,
- bool:num = true,
- ch;
- while ((ch = string[++end]) && ch != delim)
- {
- if (num)
- {
- if ('0' <= ch <= '9')
- {
- id = (id * 10) + (ch - '0');
- }
- else
- {
- num = false;
- }
- }
- }
- if (num && IsPlayerConnected(id))
- {
- setarg(paramPos, 0, id);
- }
- else
- {
- #if !defined foreach
- #define foreach(%1,%2) for (new %2 = 0; %2 < MAX_PLAYERS; %2++) if (IsPlayerConnected(%2))
- #define __SSCANF_FOREACH__
- #endif
- string[end] = '\0';
- num = false;
- new
- name[MAX_PLAYER_NAME];
- id = end - stringPos;
- foreach (Player, playerid)
- {
- GetPlayerName(playerid, name, sizeof (name));
- if (!strcmp(name, string[stringPos], true, id))
- {
- setarg(paramPos, 0, playerid);
- num = true;
- break;
- }
- }
- if (!num)
- {
- setarg(paramPos, 0, INVALID_PLAYER_ID);
- }
- string[end] = ch;
- #if defined __SSCANF_FOREACH__
- #undef foreach
- #undef __SSCANF_FOREACH__
- #endif
- }
- stringPos = end;
- }
- case 's', 'z':
- {
- new
- i = 0,
- ch;
- if (format[formatPos])
- {
- while ((ch = string[stringPos++]) && ch != delim)
- {
- setarg(paramPos, i++, ch);
- }
- if (!i)
- {
- return -1;
- }
- }
- else
- {
- while ((ch = string[stringPos++]))
- {
- setarg(paramPos, i++, ch);
- }
- }
- stringPos--;
- setarg(paramPos, i, '\0');
- }
- default:
- {
- continue;
- }
- }
- while (string[stringPos] && string[stringPos] != delim && string[stringPos] > ' ')
- {
- stringPos++;
- }
- while (string[stringPos] && (string[stringPos] == delim || string[stringPos] <= ' '))
- {
- stringPos++;
- }
- paramPos++;
- }
- do
- {
- if ((delim = format[formatPos++]) > ' ')
- {
- if (delim == '\'')
- {
- while ((delim = format[formatPos++]) && delim != '\'') {}
- }
- else if (delim != 'z')
- {
- return delim;
- }
- }
- }
- while (delim > ' ');
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement