Sign in to follow this  
Followers 0
Guest stibs

Система банов на mySQL r-39-2

1 post in this topic

Всем привет! Пишешь мод с нуля, но не можешь написать систему банов? Эта тема для тебя! 

Описание системы:

Администратор сможет банить игроков вводом команды, а также впоследствии их разбанивать по нику. Баны будут сохраняться в базе данных в формате UNIX-времени, а при показе игроку будут извлекаться из базы и конвертироваться посредством mxdate в нормальное время. 

Требования:

  1. Иметь mySQL инклуд и плагин (версии r-39, на более высокую легко перевести). 
  2. Иметь инклуд mxdate.inc. Скачать можно тут
  3. Иметь инклуд и плагин zcmd / DC_CMD / Pawn.CMD. (все не нужно, только один). 

Переходим к самой системе. 

Ко всем командам: 

Спойлер

CMD:ban(playerid,params[])
{
    //проверку на админа
    if(sscanf(params,"uds[100]",params[0],params[1],params[2])) return SendClientMessage(playerid,-1,"Используйте: /ban [ид] [кол-во дней] [причина]");
    if(!IsPlayerConnected(params[0])) return true;
    if(params[1] < 1 || params[1] > 365) return SendClientMessage(playerid,-1,"Нельзя меньше 1 дня и больше 365 дней!");
    if(playerid == params[0]) return SendClientMessage(playerid,-1,"Нельзя приминить на себе!");

    new banned[MAX_PLAYER_NAME], whobanned[MAX_PLAYER_NAME], ip[16];
    GetPlayerName(params[0], banned, MAX_PLAYER_NAME);
    GetPlayerName(playerid, whobanned, MAX_PLAYER_NAME);
    GetPlayerIp(params[0], ip, sizeof(ip));
    new query[256];
    mysql_format(dbHandle,query, sizeof(query), "INSERT INTO `banlist` ( `name`,`admin`, `bantime`, `unbantime`, `text`, `ip`) VALUES ( '%e', '%e', '%e', '%d', '%e', '%e')",banned, whobanned, gettime(),gettime()+86400*params[1],params[2],ip);
    mysql_function_query(dbHandle, query, false, "", "");

    new string[145];
    format(string, sizeof(string), "Администратор %s заблокировал %s на %d дней. Причина: %s",whobanned, banned, params[1],params[2]);
    SendClientMessage(i,-1,string);
    Kick(params[0]);

    return true;
}

CMD:unban(playerid,params[])
{
    //проверку на админа

    new name[MAX_PLAYER_NAME];
    if(sscanf(params, "s[24]", name)) return SendClientMessage(playerid, COLOR_WARNING, "Используйте: /unban [имя]");
    new query[256];
    mysql_format(dbHandle,query, sizeof(query), "SELECT * FROM `banlist` WHERE `name` = '%s'",name);
    mysql_function_query(dbHandle, query, true, "UnbanAccount", "is", playerid, name);

    return true;
}

 

Далее создаем в конце мода паблик: 

Спойлер

forward UnbanAccount(playerid, name[]);
public UnbanAccount(playerid,name[])
{
    new rows, fields;
    cache_get_data(rows, fields);
    if(!rows) return SendClientMessage(playerid,COLOR_WARNING,"[Ответ от mySQL тех. специалисту]: Данный акаунт не был заблокирован!");
    new query[150];
    mysql_format(dbHandle,query, sizeof(query), "DELETE FROM `banlist` WHERE `name` = '%s'", name);
    mysql_function_query(dbHandle, query, false, "", "");

    return true;
}

 

Далее в OnPlayerConnect вставляем: 

new names[MAX_PLAYER_NAME]; 
GetPlayerName(playerid, names, MAX_PLAYER_NAME); 
new query[150];
mysql_format(dbHandle,query, sizeof(query), "SELECT * FROM `banlist` WHERE `name` = '%e' LIMIT 1",names);
mysql_function_query(dbHandle, query, true, "CheckBan", "is", playerid, names);

В конец мода: 

Спойлер

public CheckBan(playerid, name[])
{
    new rows, fields,temp[256];
    cache_get_data(rows, fields);
    if(!rows) return /* функция загрузки аккаунта игрока */
    if(rows)
 	{
 	    new dtext[360], bantime, unbantime, text[50], id, nameadm[MAX_PLAYER_NAME];
 	    cache_get_field_content(0, "unbantime", temp), unbantime = strval (temp);
		if(gettime() < unbantime)
		{
	        cache_get_field_content(0, "id",temp), id = strval (temp);
	        cache_get_field_content(0, "bantime",temp), bantime = strval (temp);
			cache_get_field_content(0, "text", text, dbHandle);
			cache_get_field_content(0, "admin", nameadm, dbHandle);
			format(dtext,sizeof(dtext),"{FF0000}ID бана: {FFFFFF}%d\n{FF0000}Имя: {FFFFFF}%s\n{FF0000}Ник администратора: {FFFFFF}%s\n{FF0000}Причина блокировки: {FFFFFF}%s\n{FF0000}Дата блокировки: {FFFFFF}%s\n{FF0000}Дата разблокировки: {FFFFFF}%s",
			id,name,nameadm, text, date("%dd.%mm.%yyyy в %hh:%ii:%ss",bantime-10800), date("%dd.%mm.%yyyy в %hh:%ii:%ss",unbantime-10800));
			ShowPlayerDialogFix(playerid, dialog_BAN, DIALOG_STYLE_MSGBOX,"{FFCC00}Аккаунт заблокирован", dtext, "Закрыть", "");
		}
		else if(gettime() >= unbantime)
		{
	        new query[150];
   			mysql_format(dbHandle,query, sizeof(query), "DELETE FROM `banlist` WHERE `name` = '%s'", name);
	    	mysql_function_query(dbHandle, query, false, "", "");
		}
    }
    return true;
}

 

Ну а далее нам останется всего-лишь навсего сделать таблицу. 

Спойлер

CREATE TABLE IF NOT EXISTS `banlist` (
  `id` int(10) NOT NULL,
  `name` varchar(24) NOT NULL,
  `admin` varchar(24) NOT NULL,
  `bantime` int(34) NOT NULL,
  `unbantime` int(34) NOT NULL,
  `text` varchar(100) NOT NULL,
  `ip` varchar(16) NOT NULL
) ENGINE=InnoDB AUTO_INCREMENT=16 DEFAULT CHARSET=utf8;

 

На этом все! 

Автор: @stibs

Копирование на другие порталы запрещено. 

Share this post


Link to post
Share on other sites

Your content will need to be approved by a moderator

Guest
You are commenting as a guest. If you have an account, please sign in.
Reply to this topic...

×   You have pasted content with formatting.   Remove formatting

  Only 75 emoticons maximum are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

Loading...
Sign in to follow this  
Followers 0

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • Gender Bender
      By Gender Bender
      Привет, многие писали в ЛС по поводу asi плагина server_connect. Я скидывал ссылку на пост, но оказывается файлы удалили, у меня они сохранились поэтому выкладываю их сюда (ЯД)

      Пытался загрузить на форум, но файлы более 2 мб не могу. 
       
      Ссылка на исходники - click (Yandex.Disk)