В теме 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 пользователей онлайн

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

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

    • Korochansky
      От Korochansky
      Я рад объявить о выпуске первой публичной версии современной IDE с открытым исходным кодом под лицензией GPLv3 для разработки open.mp и SA-MP, которая отличается интеграцией с SAMPCTL, управлением зависимостями и встроенной поддержкой Git.
       
      Особенности:
      • Разработано специально для open.mp и SA-MP разработки.
      • Встроенная интеграция с SAMPCTL для создания, запуска и управления проектами.
      • Менеджер зависимостей для удобной установки и обновления серверных пакетов и компонентов.
      • Встроенная поддержка Git с индикаторами состояния репозитория и историей коммитов.
      • Маркеры истории изменений для отслеживания измененных и сохраненных строк.
      • Автоматическое сопоставление и выделение скобок
      • Предварительный просмотр цвета для значений RGBA и HEX прямо в редакторе.
      • Интеграция инструмента выбора цвета для быстрой вставки цветов в код Pawn.
      • Режим 'Разделенный редактор кода' для одновременной работы с несколькими файлами.
      • Дерево проекта, оптимизированное для крупных проектов.
      • Интегрированные панели вывода результатов сборки и консоли сервера.
      • Автоматический мониторинг и обновление файлов проектов.
      • Портативная версия (установка не требуется).
       
      В репозитории: https://github.com/daniilkorochansky/spawn
    • Margiela
      От Margiela
      устал от vs code + он часто конфликтует с маками, конкретно с версией M3(как у меня).
      имеются ли аналоги pawno на mac?