Гость stibs

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

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

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

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

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

Требования:

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

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

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

  Код (открыть спойлер)

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

  Код (открыть спойлер)

Далее в 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);

В конец мода: 

  Код (открыть спойлер)

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

  База данных (открыть спойлер)

На этом все! 

Автор: @stibs

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

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


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

хех, UnBanAccount забыл(

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

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

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


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

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

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


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

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

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

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

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


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

Войти

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


Войти

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

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

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

    • djxxx
      От djxxx
      приветствую всех.
       
      Задался таким вопросом при добавлении одной системы на DIALOG_STYLE_TABLIST_HEADERS.
       
      Суть проблемы в том, что диалог не выравнивается под нужные показатели, а просто как будто находиться по середине, в диалоге используется \t, но они особо не помогают в решении, также не ровно.
       
      а если попытаться выравнивать большим количеством \t, оно компилируется но в игре происходят вылеты
       
      Код такой:
      DialogAdmShop ( playerid, DIALOG_EPOINTSHOP, DIALOG_STYLE_TABLIST_HEADERS, fmt_str, ""BR"номер\t"BR"наименование\t"BR"доступное действие\n"\ "{EB4C42}#1\t{FFFFFF}Виртуальная валюта\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#2\t{FFFFFF}Донат валюта\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#3\t{FFFFFF}Вип статусы\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#4\t{FFFFFF}Кейсы\t{888888}нажмите для взаимодействия\n"\ "{EB4C42}#5\t{FFFFFF}Уникальные аксессуары\t{888888}нажмите для взаимодействия", "Выбрать", "Закрыть" ); }  
      сток dialogadmshop:
      stock DialogAdmShop(playerid, dialogid, style, title[], text[], button[], button2[]) {   if(style == 5)   {      ShowPlayerDialog(playerid, 0, DIALOG_STYLE_LIST, "...", "...", "...", "");    }   ShowPlayerDialog(playerid, dialogid, style, title, text, button, button2);   return 1; }  
    • Dev_Persona
      От Dev_Persona
      Приветствую всех, у меня возник такой вопрос:
       
      - хочу изменить базовую регистрацию в админке в крмп, на Болле сложную то-есть, сейчас изначально пароль от админки может быть только из цифр, хотелось бы узнать как можно было бы сделать что бы можно было использовать и цифры и буквы, вот код:
       
      case DIALOG_ADMIN_REG:
         {
          if(!response) return FixKick(playerid);
       
          if(strval(inputtext) < 100000 || strval(inputtext) > 999999) return ShowPlayerDialog(playerid, DIALOG_ADMIN_REG, DIALOG_STYLE_INPUT, "{FF6347}"PROJECT_NAME" {ffffff}| Придумайте пароль", "{FFFFFF}Для того, чтобы продолжить дальше - придумайте и введите\n{FFFFFF}пароль от панели администратора в диалоговое поле ниже.\n\n{FFFFFF}Пароль должен быть из 6 цифр.\n", "Готово", "");
                   SetPlayerData(playerid, P_APASS, strval(inputtext));
       
                   UpdatePlayerDatabaseInt(playerid, "AdminPassword", GetPlayerData(playerid, P_APASS));
       
                   AdminAuthorization(playerid);
         }