Разработать плагин бан системы

Недавно обновленные
Crisis
Crisis The Rebirth of the island
0.00 star(s)
Кастомная карта с размером 4500
Проект
Проект "Космодром"
0.00 star(s)
Кастомная карта с большим множеством монументов. Размер 2500
⚡Кейсы
⚡Кейсы для Вашего магазина 3D
0.00 star(s)
⚡3D Иконки кейсов для вашего магазина / Исходник PSD с возможностью редактирования текста
IQRates
IQRates
4.88 star(s)
Рейтинг контроллер на ваш сервер! Без излишеств с удобным функционалом!
IQTurrets
IQTurrets
5.00 star(s)
Турели без электричества с лимитами на игрока/шкаф
IQWipeBlock
IQWipeBlock
5.00 star(s)
Многофункциональная система временной блокировки
Grand
Grand Island
0.00 star(s)
Карта представленная в виде нескольких больших островов и нескольких малых
Sunrise:
Sunrise: The Last Place Of Being
0.00 star(s)
Этот остров открывает перед нами новый мир, в который отправляются сильнейшие испытатели Кобальта...
Трансильвания
Трансильвания
0.00 star(s)
Отличная карта со страшными монументами))
Last
Last Oasis
5.00 star(s)
Планета Земля замедляет вращение и солнце все сильнее начинает прожигать землю.....
🌞
🌞 Летнее оформление для VK
5.00 star(s)
🌞 3D Оформление / Исходник PSD с возможностью редактирования текста
Набор
Набор из 10 кастомных пещер 3
0.00 star(s)
Кастомные места для застройки
Чернобыль:
Чернобыль: Зона отчуждения
5.00 star(s)
Атмосферная карта
IQGuardianDrone
IQGuardianDrone
4.33 star(s)
Дрон-защитник, который может сопровождать ваших игроков в любом бою
IQPotionFarm
IQPotionFarm
5.00 star(s)
"Зельевая" ферма, которая добавит возможность выпить его или продать!

pokemon

Пользователь
Messages
84
Reaction score
11
Приветствую.
Необходимо разработать плагин по типу EnhancedBanSystem
EnhancedBanSystem - не подходит много лишнего

ТЗ:

1. Перехват бана, чтобы баны не писали в bans.cfg
2. Сохранение банов в Mysql

Структура таблиц:

Таблица - `servers`
Поля:
- id (auto_increment, int 11)
- server_name (varchar 100)
- server_address (ip:port) (varchar 100)

Таблица - `bans`

Поля:

- id (auto_increment, int 11)
- steam_id (varchar 100)
- nickname (varchar 100)
- reason (varchar 100)
- ip (varchar 100)
- owner
- expired (decimal)
- server_id
- created (datetime)
- updated (datetime)

owner - ник админа который выдал бан:steamID, при автоматическом бане античитом значение "Server"
nickname - есть проблема в EnhancedBanSystem что символы не читаемы растом в нике вызывают фейл и бан не записывается в БД, нужно это решить, может заменой ника на steam_id игрока
reason - будет либо от античита своя либо та которую указали при бане с консоли: ban [STEAMID] [читак] [TIME:1h OR 1d...] или в чате на сервере имея определенный пермишен /ban [STEAMID] [читак] [TIME:1h OR 1d...]
ip - ip игрока
expired - как указал тип данных для хранения "decimal", в случае бана навсегда значение 0, в случае на время unixtime(или что там понятное для раста, при кике пишет на сколько забанен), значение -1 разбанен

Таблица - `unban`

- id (auto_increment, int 11)
- ban_id (int 11)
- owner
- created (datetime)

owner - ник админа который разбанил:steamId
ban_id - связь с таблицей bans -> id

При выполнении команды с консоли: unban [STEAMID] или в чате на сервере имея определенный пермишен /unban [STEAMID]

3. При заходе игрок проверяется в базе на наличие активных банов на всех серверах, если есть бан хоть на каком либо - кик [reason] [expired] ? [expired]:''
4. Должны быть ланги для RU и EN
5. Раздельные пермишены на бан и разбан
6. Конфиг должен иметь белый списк ip, данный ip из списка игнорируется в случае обхода бана и игрок не отлетает (актуально для тех кто играет с 1 ip и 1 банится и все за ним атоматом).
7. При бане проверка на обход бана сменой аккаунта, проверяется на совпадение ip и если есть бан с там же - бан, причину настраивать в конфиге, дефолт Ban Evade
8. Добавить в конфиг возможность указать свою иконку и префикс для сообщений в чате.
9. Логирование в DiscordMessages по Discord Webhook Url, -> Oxide.Ext.Discord.dll

Формат лога в DS:
Ник игрока (steam id | ip) был забанен за: [reason]


Мой дискорд для связи Ghoster#2473
 
Back
Top Bottom