Гость stibs

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

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

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

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

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

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

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


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

хех, UnBanAccount забыл(

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

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

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


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

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

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


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

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

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

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

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


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

Войти

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


Войти

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

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

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

    • KAIF
      От KAIF


      Скачать файл GTA RolePlay-МОД,СБОРКА
      !!!!!ВСЕГО ОДНА КОПИЯ!!!! 
      Единственный мод GTA RP.
       
      Фракции:
      Правительство
      ГИБДД
      Полиция Южного
      ФСБ
      ЦГБ-А
      Автошкола
      Китайская мафия
      Русская Мафия
      Итальянская Мафия
      Американская Мафия
      Чеченская Мафия
      ВВС
      МЧС
      ОПГ Тяп-Ляп
      ОПГ Хади-Такташ
      СМИ Южного
      ФСИН
      В комплекте идёт СБОРКА И МОД.
      Единственный мод GTA RP.
      Добавил KAIF Добавлено 01.01.2024 Категория Моды Автор Aleksandr  
    • KAIF
      От KAIF
      !!!!!ВСЕГО ОДНА КОПИЯ!!!! 
      Единственный мод GTA RP.
       
      Фракции:
      Правительство
      ГИБДД
      Полиция Южного
      ФСБ
      ЦГБ-А
      Автошкола
      Китайская мафия
      Русская Мафия
      Итальянская Мафия
      Американская Мафия
      Чеченская Мафия
      ВВС
      МЧС
      ОПГ Тяп-Ляп
      ОПГ Хади-Такташ
      СМИ Южного
      ФСИН
      В комплекте идёт СБОРКА И МОД.
      Единственный мод GTA RP.
    • Узбек
      От Узбек
      Всем добрый вечер ребят! 
      Я начинающий, сегодня я вам сливаю команду 2(шт) на технические работы
      Ловите