Архив: Веб-гейт серверной консоли. Minecraft, JAVA, Plugin, Spigot, Web

Бюджет По договоренности
Создан: 6 лет назад
Закрыт
Описание
Техзадание — плагин: Веб-гейт серверной консоли



Тэги: Minecraft, JAVA, Plugin, Spigot, Web





Общие сведения:



Плагин нужно разработать на JAVA в формате пригодном для взаимодействия с Minecraft ядром Spigot версии 1.12 (https://www.spigotmc.org/). Для успешной разработки плагина желательны навыки разработки ПО под Minecraft и навыки работы с сетевыми протоколами, в частности реализацией веб-протокола (серверного) на Java. Полезная информация для разработки Spigot плагинов: https://www.spigotmc.org/wiki/spigot-plugin-development/











Роль плагина в общей картине:







Плагин должен предоставлять веб-интерфейс для чтения данных из консоли и для отправки команд в консоль.



Описание отдельных опций:



Пример: config.yml плагина

#########################################################################

#IP адрес, по которому будет запущен веб-сервер (0.0.0.0 - все доступные)

Server IP: 0.0.0.0



#Порт веб-сервера

Server port: 25580



#Cписок IP адресов, с которых есть доступ к веб-интерфейсу

IP access list:

-1.1.1.1

-2.2.2.2

-3.3.3.3



#Пароль, по которому IP адрес временно добавляется в список доступа по IP в памяти

Access password: qwertyrtyqe



#Длительность сессии авторизации по паролю, минут (-1 - постоянно, до перезапуска)

Session time: -1



#Временной интервал содержимого консоли, хранимый в памяти плагина для ответа через веб, секунд (макс. до 86400 /1сутки)

Console Memory Buffer Time: 3600



#Ограничение числа строк, хранимое в памяти плагина для ответа через веб

Console Memory Buffer Strings: 100000



#########################################################################





1) Авторизация по IP или логин-пароль.



Пример веб-запроса на авторизацию:

http://site.com/auth.cgi?code= qwertyrtyqe (разумеется GET запрос показан для примера, плагин должен принимать данные и в POST запросе аналогично)



Если авторизация успешна, веб-сервер должен возвратить в ответ на этот запрос результат действия - веб страницу содержающую plain text, например:

auth=true,ip=1.1.1.1,expired=

или если пароль не верен:

auth=false

Если пароль введен неверно более 3х раз - на 10 минут блокировать IP адрес, который пытался пройти авторизацию - не обрабатывать попытки авторизации, а выдавать код ответа веб-сервера 403.



Запрос не нужно выполнять если его успешно выполнили и сессия не окончена или пользователь есть в списке IP access list.



Чтобы принудительно завершить сессию, нужно отправить запрос http://site.com/auth.cgi?quit=true

Ответ, отправляемый на этот запрос - auth=false.





2) Отправка команд в консоль.



Брать команду из веб-запроса: http://site.com/rcon.cgi?cmd= (разумеется GET запрос показан для примера, плагин должен принимать данные и в POST запросе аналогично)

И отправлять ее в обработку сервером как из консоли.

Веб-клиенту запросившему команду возвращать веб-страницу с результатом выполнения команды в plain text.





3) Чтение консоли.



По команде из веб-запроса http://site.com/rcon.c
Категория