В теме 1 сообщение

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

Всем здарова! Недавно выкладывал систему слета неактивных аккаунтов на mxINI, сегодня мы сделаем то же самое, но на MySQL r-39.

Суть системы та  же: она будет удалять неактивные аккаунты, т.е. те аккаунты, владельцы которых не заходили на сервер более N-дней (указывается в макросе - define).

Настройки:

Настраивается система просто, на дефайнах. Там можно указать кол-во дней, за который аккаунт считается неактивным. Также на в дефайне нужно прописать таблицу с аккаунтами и поле с последней датой захода.

Требования:

  • Стандартный инклуд a_samp и прилагающиеся к нему библиотеки.
  • Инклуд и плагин MySQL версии R-39. Можно легко перевести на более высокую версию.
  • Немного мозгов и прямых рук.

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

Ко всем дефайнам:

#define N_DAYS		30 // кол-во дней, через которое аккаунт будет считаться неактивным
#define	N_TABLE		"accounts" // таблица с аккаунтами
#define N_FIELD		"lastlogin" // поле с последним заходом игрока
#define N_NAME		"name" // поле с ником игрока

ВНИМАНИЕ! Поле с последним заходом должно быть уже создано в вашей базу данных, иначе система работать не будет.

  Параметры для поля (открыть спойлер)

Идем в OnPlayerConnect и добавляем следующий код:

new query[150], name[MAX_PLAYER_NAME];
GetPlayerName(playerid, name, sizeof(name));
mysql_format(dbHandle, query, sizeof(query), "UPDATE "N_TABLE" SET "N_FIELD" = '%d' WHERE "T_NAME" = '%s'", gettime(), name);
mysql_function_query(dbHandle, query, false, "", "");

Далее добавим в OnGameModeInit

public OnGameModeInit()
{
    mysql_function_query(dbHandle, "SELECT * FROM "N_TABLE"", true, "CheckAccountDelete", "");
    return true;
}

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

forward CheckAccountDelete();
public CheckAccountDelete()
{
    new rows, fields;
    cache_get_data(rows, fields);
    if(!rows) return print("В указанной таблице не обнаружено строк!");
    new count, tick = GetTickCount(), lastlogin;
    for(new r; r<rows; r++)
    {
        lastlogin = cache_get_field_content_int(r, ""N_FIELD"");
        if(gettime()-lastlogin > N_DAYS*86400)
        {
            new name[MAX_PLAYER_NAME];
            cache_get_field_content(r, ""N_NAME"", name, dbHandle, 24);
            mysql_format(dbHandle, query, sizeof(query), "DELETE FROM "N_TABLE" WHERE "N_NAME" = '%s'", name);
            mysql_function_query(dbHandle, query, false, "", ""); // удаляем аккаунт
            printf("Аккаунт с ником %s был удален из базы, так как прошло более %d дней с момента регистрации!", name, N_DAYS);
            count++;
        }
    }
    printf("ОБЩАЯ СТАТИСТИКА ОЧИСТКИ АККАУНТОВ: %d аккаунтов удалено, %d - время, за которое они очищены (мс)", %d - всего выполнений цикла (аккаунтов)", count, GetTickCount()-tick, rows);
    return true;
}

ВНИМАНИЕ! Данная система может вызвать незапланированную нагрузку на сервер. Поэтому, рекомендуется применять данную систему ночью, когда игроков практически нет. 
Среднее время выполнения цикла for в 10 000 итераций (допустим, что у нас 10 000 аккаунтов) - 2 с.

Автор: @DEST и @stibs.

При копировании обязательно указывайте авторство. 

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


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

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

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

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

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


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

Войти

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


Войти

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

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

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

    • hatriyikko
      От hatriyikko
      Требуется мобильная сборка мод + клиент + лаунчер

      Копия Радмира, Блэк Раши или что-то другое с аналогичным функционалом. Основной упор на бизнесы, чтобы всё исправно работало
       
      Напишите сколько это будет стоить?

      В дальнейшем также могут понадобиться какие то доработки мода, если всё ок рассматриваю долгосрочное сотрудничество

      Связь тут или в тг @kovart7
    • whccompany
      От whccompany
      World Hosting Corporations 
                                                                GTA Game Host 
                                               CRMP PC& Mobile Project 
                                           Rostov Role Play | Rostov RP 
      Друзья, нашему проекту срочно требуется маппер для масштабного маппинга, нам требуется сделать:
      1) Городской маппинг (удалить города и создать новые города, сначало необходимо создать город Ростов-на-Дону ; посёлок Коксовый и село Ряженое, создать используя стоковые фотографии из Яндекса и Гугла)
      2) Фракционный маппинг ( Текстуры + Экстерьер + Интерьер )
      3) Маппинг работ ( Текстуры + Экстерьеры + Интерьеры )
      Бюджет до 60 000 рублей
      Возможно заключение трудового контракта 
      Пишите: ВКонтакте

    • gooding
      От gooding
      Всем здравствуйте, уважаемые читатели. Я много времени потратил на доработку данного игрового мода, чтобы его выставить на форум.
      Лог доработок можно посмотреть внизу, а скриншоты игрового мода внизу и верху.