Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- ////////////////////////////////////////////////////////////////////////////////
- ///////////////////////////////--- Ban system ---///////////////////////////////
- /////////////////////////--- © by KABOOM aka Norman ---/////////////////////////
- ////////////////////////////////////////////////////////////////////////////////
- #define dcmd(%1,%2,%3) if ((strcmp((%3)[1], #%1, true, (%2)) == 0) && ((((%3)[(%2) + 1] == 0) && (dcmd_%1(playerid, "")))||(((%3)[(%2) + 1] == 32) && (dcmd_%1(playerid, (%3)[(%2) + 2]))))) return 1
- #include <a_samp>
- #include <dini>
- #define violet 0x9600FFFF
- #define hellblau 0x00E1FFFF
- #define rot 0xFF0A00FF
- public OnFilterScriptInit()
- {
- print("\n-------------------------------------");
- print("*** Ban system by KABOOM aka Norman ***");
- print("-------------------------------------\n");
- return 1;
- }
- public OnFilterScriptExit()
- {
- return 1;
- }
- public OnPlayerConnect(playerid)
- {
- new banFormat[128],pname[MAX_PLAYER_NAME];
- GetPlayerName(playerid,pname,sizeof(pname));
- format(banFormat,sizeof(banFormat),"Bans/%s.txt",pname);
- if(dini_Exists(banFormat))
- {
- SendClientMessage(playerid, rot, "DU BIST GEBANNT VON DIESEM SERVER!");
- Kick(playerid);
- }
- else
- {
- //Das passiert wenn der Spieler nicht gebannt ist...
- }
- return 1;
- }
- public OnPlayerCommandText(playerid, cmdtext[])
- {
- dcmd(ban,3,cmdtext);
- dcmd(unban,5,cmdtext);
- return 0;
- }
- dcmd_ban(playerid, params[])
- {
- new pID, sGrund[128],pname[MAX_PLAYER_NAME],aname[MAX_PLAYER_NAME],banFormat[128],
- Year, Month, Day, Hour, Minute, Second,
- timestring[128], datestring[128], string[128], string2[128], string3[128];
- GetPlayerName(pID,pname,sizeof(pname));
- format(banFormat,sizeof(banFormat),"Bans/%s.txt",pname);
- if(IsPlayerAdmin(playerid)) {
- return SendClientMessage(playerid,rot,"Du bist kein Admin");
- }
- if(sscanf(params, "us",pID,sGrund)) {
- return SendClientMessage(playerid,rot,"Benutze: '/ban [Spieler ID] [Grund]'");
- }
- if(pID == INVALID_PLAYER_ID) {
- SendClientMessage(playerid, rot, "Ungültige ID!");
- }
- if(dini_Exists(banFormat))
- {
- SendClientMessage(playerid,rot,"Dieser Spieler ist schon gebannt!");
- }
- else
- {
- getdate(Year, Month, Day);
- gettime(Hour, Minute, Second);
- format(timestring,sizeof(timestring),"%02d:%02d:%02d",Hour, Minute, Second);
- format(datestring,sizeof(datestring),"%02d/%02d/%d",Day,Month,Year);
- GetPlayerName(playerid,aname,sizeof(aname));
- dini_Create(banFormat);
- dini_Set(banFormat, "Date",datestring);
- dini_Set(banFormat, "Time",timestring);
- dini_Set(banFormat, "Reason",sGrund);
- dini_Set(banFormat, "Admin",aname);
- format(string,sizeof(string),"Du hast %s gebannt! (Grund: %s)",pname,sGrund);
- SendClientMessage(playerid,hellblau,string);
- format(string2,sizeof(string2),"Du wurdest von Admin %s gebannt! (Grund: %s)",aname,sGrund);
- SendClientMessage(playerid,violet,string2);
- Kick(pID);
- format(string3,sizeof(string3),"%s wurde von Admin %s gebannt! (Grund: %s)",pname,aname,sGrund);
- SendClientMessageToAll(violet,string3);
- }
- return 1;
- }
- dcmd_unban(playerid, params[])
- {
- new banFormat[128], name[MAX_PLAYER_NAME],aname[MAX_PLAYER_NAME],
- string[128],string2[128];
- if(IsPlayerAdmin(playerid)) {
- return SendClientMessage(playerid,rot,"Du bist kein Admin");
- }
- if(sscanf(params, "s",name)) {
- return SendClientMessage(playerid,rot,"Benutze: '/unban [Spielername]'");
- }
- format(banFormat,sizeof(banFormat),"Bans/%s.txt",name);
- if(fexist(banFormat))
- {
- dini_Remove(banFormat);
- GetPlayerName(playerid,aname,sizeof(aname));
- format(string,sizeof(string),"Du hast %s entbannt!",name);
- format(string2,sizeof(string2),"Admin %s hat %s entbannt!", aname, name);
- SendClientMessage(playerid, hellblau, string);
- SendClientMessageToAll(violet,string2);
- }
- else
- {
- SendClientMessage(playerid, rot, "Dieser Spieler ist nicht gebannt!");
- }
- return 1;
- }
- //=========================================================================================================================//
- //=================================================== SCANF CODE ==========================================================//
- //=========================================================================================================================//
- 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