В теме 3 сообщения

Гость stibs
Новичок

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

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

Администратор сможет банить игроков вводом команды, а также впоследствии их разбанивать по нику. Баны будут сохраняться в базе данных в формате 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

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

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Mishunin
Освоившийся

хех, UnBanAccount забыл(

upd: есть, буду внимателен

Отредактировано пользователем Mishunin

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
Sleash
Завсегдатый

В спойлере кода "в конец мода" нет форварда CheckBan (простые копипастеры не поймут в чём проблема и будут компостировать тебе мозги)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!


Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.


Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Maxwell
      От Maxwell
      Ребята, мб есть у кого код на /rec, реконект то есть.
    • hunter.
      От hunter.
      Те кто следят за мододелами GTA San Andreas возможно уже вкурсе о выходе модификации которая добавляет с нуля созданный Карцер-Сити из Мэнхант.

      Суть заказа состоит в том, чтобы адаптировать SA:MP под данную модификацию.

      Бюджет свободный
      Контакты для связи:
      tg: @yomabooy