Dedicated-Server.RU

Dedicated-Server.RU (http://www.dedicated-server.ru/vbb/forum.php)
-   Движок ReHLDS, ReGameDLL и эксклюзивные дополнения к ним (http://www.dedicated-server.ru/vbb/forumdisplay.php?f=179)
-   -   Rechecker (Проверка ресурсов для ReHLDS) (http://www.dedicated-server.ru/vbb/showthread.php?t=26550)

s1lent 14.11.2015 22:49

Rechecker (Проверка ресурсов для ReHLDS)
 
Вложений: 8
ВНИМАНИЕ: Публикация на сторонних ресурсах запрещена без согласования с автором!
Resources Checker
Автор:
  • s1lent
Описание:
Rechecker это Metamod plugin, дающий возможность проверять клиентские файлы по их md5 хэшу.
Возможное применение:
  • Обнаружение читерских библиотек в директории игры
  • Обнаружение отсутствия обязательных для игры файлов
  • Обнаружение запрещенных моделей игроков, либо создание белого списка разрешенных
Требования:
  • Движок ReHLDS 937 или новее
  • MetaMod 1.20(p) или новее
Установка:

Подробнее...

  • Распаковываем rechecker_X_X.zip в папку <gamedir> вашей игры.
  • Добавляем библиотеку rechecker_mm_i386.so или rechecker_mm.dll в зависимости от используемой ОС в конфиг MetaMod.
    Для этого открываем <gamedir>/addons/metamod/plugins.ini (если его нет, создаем сами) и пишем:
    Linux:
    Цитата:

    linux addons/rechecker/rechecker_mm_i386.so
    Windows:
    Цитата:

    win32 addons\rechecker\rechecker_mm.dll
  • Из извлеченного архива rechecker_X_X.zip будет присутствовать файл resources.ini который должен лежать рядом с библиотекой rechecker_mm.dll или rechecker_mm_i386.so

  • Запускаем сервер и командой meta list проверяем статус
    Linux:
    Цитата:

    Currently loaded plugins:
    description stat pend file vers src load unlod
    [ 1] Rechecker RUN - rechecker_mm_i386.so vX.X ini Chlvl Any

    Windows
    Цитата:

    Currently loaded plugins:
    description stat pend file vers src load unlod
    [ 1] Rechecker RUN - rechecker_mm.dll vX.X ini Chlvl Any

  • Установка Rechecker завершена
[свернуть]
CVAR:

Подробнее...

  • rch_log - 0/1/2
    • 0 - Выключить.
    • 1 - Обычный лог, только обнаружение.
    • 2 - Детальный лог.
[свернуть]
Дополнительно:

Подробнее...


Описание флагов:
  • UNKNOWN - Если вам неизвестен хэш, при таком флаге будет искать файл с любым хэшем.
  • IGNORE - Это флаг который помечает данный файл с хэшем в игнорируемый список.
  • MISSING - Обнаружение отсутствие файла у клиента.

    Если 2 файла с указанным хэшем и с флагом IGNORE были обнаружены,
    то для UNKNOWN они будут проигнорированы

    "../qwerty.dll" 099b3b06 IGNORE
    "../qwerty.dll" f284f878 IGNORE
    "../qwerty.dll" UNKNOWN "addip 1440 [ip]"


  • BREAK - Этот флаг выходит из всех проверок если файл был обнаружен или наоборот отсутствует.

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

    "../anticheat.dll" bdc52384 BREAK
    "../opengl32.dll" 0ee4e274 "addip 1440 [ip]"

Разбор лога:
  • exphash - `expected hash` хэш который ожидает получить
  • got - хэш который пришел от клиента
  • typeFind - тип обнаружения
    • exists - сравнение хэша `exphash == got`
    • missing - проверка на отсутствие файла `prevhash == got`
    • ignore - файлы помеченные в игнор
    • hash_any - проверка на любой хэш `prevhash != got`


  • prevhash - хэш предыдущего файла prevfile
  • prevfile - предыдущий файл
  • md5hex - хэш как указан в resources.ini, тоже самое что и exphash - разница только в порядке байтов от младшего к старшему
  • findathash - встречался ли ранее такой хэш во всех проверяемых файлов
Форматирование строк:
  • [name] - Имя игрока
  • [ip] - IP Адрес игрока
  • [userid] - идентификатор игрока
  • [steamid] - Steamid игрока

  • [file_name] - имя проверяемого файла
  • [file_hash] - хэш проверяемого файла который вернул клиент
    (Внимание: этот хэш big-endian, если вы хотите получить хеш для последующего применения в resources.ini то используйте file_md5hash)
  • [file_md5hash] - хэш проверяемого файла который вернул клиент

Полезные примечания:
  • Причину наказания или оповещения можно заключать в одинарные кавычки. "amx_kick [userid] 'Opengl32 Detected'"
  • md5 хэш c8005c526355d8015d462dc7f4ddb159 достаточно иметь первые 4 байта (c8005c52)
[свернуть]
Изменения:

Подробнее...


2.4 (24 Сентября 2017)
  • Обновление Rechecker API 2.1
  • Добавлена поддержка UTF-8 BOM для resources.ini
  • Исправлены некоторые незначительные ошибки.
  • Убрана проверка на расширение у запрашиваемого файла.
2.3 (13 Декабря 2016)
  • Исправлен запуск модуля на Linux.
2.2 (12 Декабря 2016)
  • Поддержка ReHLDS с версией API 3.х (build 3.0.0.361 и выше)
  • Добавлен интерфейс Rechecker API для 3rd-party
2.1 (5 Мая 2016)
  • Расширен лимит ресурсов с 1280 до 4096.
2.0 (1 Марта 2016)
  • Исправлено ложное обнаружение в некоторых случаях.
  • Изменен квар rch_log 0/1/2 (0 - Выключить/1 - Обнаружение/2 - Детальный лог).
1.7 - 1.9 (28 Января 2016)
  • Убран квар rch_delay.
  • Исправлен баг с получением файлов в неправильном порядке.
  • Обновлен ReHLSDK (ReHLDS build 654 или новее)
1.6 (20 Января 2016)
  • Добавлен квар rch_delay. Отложенное время до выполнения cmd. (По умолчанию: 0).
1.5 (11 Января 2016)
  • Исправлена некорректность данных в логах.
1.4 (11 Января 2016)
  • Исправлено 'Bad file data'.
  • Добавлен флаг 'MISSING' на замену хэша 00000000.
1.2 (18 Ноября 2015)
  • Исправлен баг с флагом BREAK.
  • Добавлена возможность выгрузки через meta unload.
  • Добавлена база для примера.
1.1 (17 Ноября 2015)
  • Исправлен баг с отображением даты в логах.
  • Добавлены доп. поля в лог-файл.
1.0 (15 Ноября 2015)
  • Первый релиз
[свернуть]
Благодарности:
  • dreamstalker за проект ReHLDS
  • Asmodai за консультацию и помощь в реализации оптимизации.
  • Neygomon за проведение тестов.

Обсуждаемая база читов:
Исходники:
Скрытый блок (для группы пользователей: Super Moderator :: 5, Administrator :: 6, DS.RU Moderator :: 7, Special DS.RU :: 19, DS.RU User :: 24):
Вы не имеете достаточно прав, чтобы видеть скрытый текст, содержащийся здесь.
Текущая версия 2.4:

Kain_wrath 15.11.2015 02:20

Для обычного билда, НЕ ReHLDS, этот модуль планируется?

s1lent 15.11.2015 02:53

Цитата:

Сообщение от Kain_wrath (Сообщение 290267)
Для обычного билда, НЕ ReHLDS, этот модуль планируется?

этот метамод плагин делался исключительно по одной причине, для rehlds нет аналогов.
Поэтому мой ответ - не планирую.

Subb98 15.11.2015 10:32

Здорово! Ещё одна причина опробовать ReHLDS!

LeninChan^^ 16.11.2015 16:16

Список файлов обновляется при смене карты?

s1lent 16.11.2015 16:43

Цитата:

Сообщение от LeninChan^^ (Сообщение 290294)
Список файлов обновляется при смене карты?

да.

LeninChan^^ 16.11.2015 22:34

Ломается лог файл при выполнении команды

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


http://i.imgur.com/oAGuAfa.png
[свернуть]

s1lent 16.11.2015 23:13

Цитата:

Сообщение от LeninChan^^ (Сообщение 290299)
Ломается лог файл при выполнении команды

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


http://i.imgur.com/oAGuAfa.png
[свернуть]

не ломается, для server execute используется в конце перенос строки '\n', для логирования - уберу.

9iky6 16.11.2015 23:30

Вложений: 1
Спасибо за модуль. Прикольнуло только скачивание на Vivaldi :beta:
P.S. S1lent'у давно пора выкладывать ссылки на донат.

s1lent 17.11.2015 10:11


Обновлено 1.1
  • Исправлен баг с отображением даты в логах.
  • Добавлены доп. поля в лог-файл.

s1lent 18.11.2015 10:38


Обновлено 1.2
  • Исправлен баг с флагом BREAK.
  • Добавлена возможность выгрузки через meta unload.
  • Добавлена база для примера.

paster 18.11.2015 17:22

Подключив сошку
Цитата:

linux addons/rechecker/rechecker_mm_i386.so
Сервер не поднимается.

Цитата:

ОС: Linux Gentoo
Metamod v1.21p37

s1lent 18.11.2015 17:30

Цитата:

Сообщение от paster (Сообщение 290330)
Сервер не поднимается.

Можно побольше информации о сервере?
например билд.

paster 18.11.2015 19:06

Цитата:

Protocol version 48
Exe version 1.1.2.7/Stdio (cstrike)
Exe build: 17:35:00 Oct 16 2015 (552)
ReHLDS API version 2.2
Обрыв записи:
Цитата:

[WHB] Version: 1.5.620 Linux
[WHB] Success: Build ReHLDS version defined Linux "552"
[WHB] Success: Configuration executed.
./hlds_run: line 255: 26089 Segmentation fault $HL_CMD

s1lent 18.11.2015 19:21

paster,

Цитата:

Сообщение от s1lent (Сообщение 290266)
Требования:
  • Движок ReHLDS >= build 581

вам надо обновить rehlds


Текущее время: 21:33. Часовой пояс GMT +3.

Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2017, vBulletin Solutions, Inc. Перевод: zCarot
Лицензия принадлежит Dedicated-Server.Ru