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

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

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

    • I'm Fine
      От I'm Fine
      Доброго времени суток! Не понимаю почему не работает CEF.
      Сервер SAMP-R3, Игра GTA:CR и накинул на неё CustomSAA2 и прочее из туториала по переносу карты CRMP на SAMP, так же поставил SAMP 0.3.7-R3.
      Файлы я закинул на Google диск ниже. В чем может быть проблема?

      https://drive.google.com/drive/folders/1GPo5f8xi0w8TUuTPvkaCArnD1rCqvfAX?usp=sharing

      Сейчас пробую установить GTA:SA и в неё закинуть файлы для карты crmp (где то читал что вроде в GTA:CR cef работать не будет)