diff --git a/resources/config.yml b/resources/config.yml index 336a6a46..55f5f847 100644 --- a/resources/config.yml +++ b/resources/config.yml @@ -4,6 +4,9 @@ interface: 0.0.0.0 port: 25565 +#Sets the server description on the server list +motd: "§bPocketMine-MP server using §6§lBigBrother§r§b plugin\n§aConnect to Minecraft: PE servers from PC clients" + #Use Mojang services to authenticate players online-mode: true diff --git a/src/shoghicp/BigBrother/BigBrother.php b/src/shoghicp/BigBrother/BigBrother.php index 876def8a..5a3a3e49 100644 --- a/src/shoghicp/BigBrother/BigBrother.php +++ b/src/shoghicp/BigBrother/BigBrother.php @@ -64,6 +64,7 @@ class_exists("phpseclib\\Crypt\\AES", true); public function onEnable(){ $this->saveDefaultConfig(); + $this->saveResource("server-icon.png", false); $this->reloadConfig(); //TODO: work on online mode @@ -73,6 +74,10 @@ public function onEnable(){ $this->getLogger()->notice("no mcrypt detected, online-mode has been disabled. Try using the latest PHP binaries"); } + if(!$this->getConfig()->exists("motd")){ + $this->getLogger()->warning("No motd has been set. The server description will be empty."); + } + if(Info::CURRENT_PROTOCOL === 16){ $this->translator = new Translator_16(); }else{ @@ -106,7 +111,7 @@ protected function enableServer(){ $port = (int) $this->getConfig()->get("port"); $interface = $this->getConfig()->get("interface"); $this->getLogger()->info("Starting Minecraft: PC server on ".($interface === "0.0.0.0" ? "*" : $interface).":$port version ".MCInfo::VERSION); - $this->thread = new ServerThread($this->getServer()->getLogger(), $this->getServer()->getLoader(), $port, $interface); + $this->thread = new ServerThread($this->getServer()->getLogger(), $this->getServer()->getLoader(), $port, $interface, (string) $this->getConfig()->get("motd"), $this->getDataFolder() . "server-icon.png"); $this->interface = new ProtocolInterface($this, $this->thread, $this->translator); $this->getServer()->addInterface($this->interface); diff --git a/src/shoghicp/BigBrother/network/ServerManager.php b/src/shoghicp/BigBrother/network/ServerManager.php index 857720c6..300bedf5 100644 --- a/src/shoghicp/BigBrother/network/ServerManager.php +++ b/src/shoghicp/BigBrother/network/ServerManager.php @@ -82,10 +82,17 @@ class ServerManager{ public $maxPlayers = 20; /** @var string[] */ public $sample = []; - public $description = "§bPocketMine-MP server using §6§lBigBrother§r§b plugin\n§aConnect to Minecraft: PE servers from PC clients"; - public $favicon = ""; + public $description; + public $favicon; + + public function __construct(ServerThread $thread, $port, $interface, $description = "", $favicon = null){ + $this->description = $description; + if($favicon === null or ($image = file_get_contents($favicon)) == ""){ + $this->favicon = null; + }else{ + $this->favicon = "data:image/png;base64,".base64_encode($favicon); + } - public function __construct(ServerThread $thread, $port, $interface){ $this->logger = $thread->getLogger(); $this->fp = $thread->getInternalIPC(); if($interface === ""){ diff --git a/src/shoghicp/BigBrother/network/ServerThread.php b/src/shoghicp/BigBrother/network/ServerThread.php index 20849cc8..c076d64e 100644 --- a/src/shoghicp/BigBrother/network/ServerThread.php +++ b/src/shoghicp/BigBrother/network/ServerThread.php @@ -24,6 +24,7 @@ class ServerThread extends \Thread{ /** @var \ThreadedLogger */ protected $logger; protected $loader; + protected $data = []; public $loadPaths = []; @@ -37,10 +38,12 @@ class ServerThread extends \Thread{ * @param \SplAutoloader $loader * @param int $port 1-65536 * @param string $interface + * @param string $motd + * @param string $icon * * @throws \Exception */ - public function __construct(\ThreadedLogger $logger, \SplAutoloader $loader, $port, $interface = "0.0.0.0"){ + public function __construct(\ThreadedLogger $logger, \SplAutoloader $loader, $port, $interface = "0.0.0.0", $motd = "Minecraft: PE server", $icon = null){ $this->port = (int) $port; if($port < 1 or $port > 65536){ throw new \Exception("Invalid port range"); @@ -49,6 +52,10 @@ public function __construct(\ThreadedLogger $logger, \SplAutoloader $loader, $po $this->interface = $interface; $this->logger = $logger; $this->loader = $loader; + $this->data = serialize([ + "motd" => $motd, + "icon" => $icon + ]); $loadPaths = []; $this->addDependency($loadPaths, new \ReflectionClass($logger)); $this->addDependency($loadPaths, new \ReflectionClass($loader)); @@ -124,7 +131,7 @@ public function run(){ } } $this->loader->register(); - - $manager = new ServerManager($this, $this->port, $this->interface); + $data = unserialize($this->data); + $manager = new ServerManager($this, $this->port, $this->interface, $data["motd"], $data["icon"]); } } \ No newline at end of file diff --git a/src/shoghicp/BigBrother/network/Session.php b/src/shoghicp/BigBrother/network/Session.php index ffabce54..d3bc50e7 100644 --- a/src/shoghicp/BigBrother/network/Session.php +++ b/src/shoghicp/BigBrother/network/Session.php @@ -118,7 +118,7 @@ public function process(){ "id" => $id ]; } - $data = json_encode([ + $data = [ "version" => [ "name" => Info::VERSION, "protocol" => Info::PROTOCOL @@ -128,9 +128,12 @@ public function process(){ "online" => $this->manager->players, "sample" => $sample, ], - "description" => $this->manager->description, - "favicon" => $this->manager->favicon - ], JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); + "description" => json_decode(TextFormat::toJSON($this->manager->description)) + ]; + if($this->manager->favicon !== null){ + $data["favicon"] = $this->manager->favicon; + } + $data = json_encode($data, JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); $data = Binary::writeVarInt(0x00) . Binary::writeVarInt(strlen($data)) . $data; $this->writeRaw($data);