mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-07-03 08:39:53 +00:00
153 lines
4.9 KiB
PHP
153 lines
4.9 KiB
PHP
<?php
|
|
|
|
/*
|
|
*
|
|
* ____ _ _ __ __ _ __ __ ____
|
|
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
|
|
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
|
|
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
|
|
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* @author PocketMine Team
|
|
* @link http://www.pocketmine.net/
|
|
*
|
|
*
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace pocketmine\command\defaults;
|
|
|
|
use pocketmine\command\CommandSender;
|
|
use pocketmine\command\utils\InvalidCommandSyntaxException;
|
|
use pocketmine\event\TimingsHandler;
|
|
use pocketmine\event\TranslationContainer;
|
|
use pocketmine\Player;
|
|
use pocketmine\scheduler\BulkCurlTask;
|
|
use pocketmine\Server;
|
|
|
|
class TimingsCommand extends VanillaCommand{
|
|
|
|
public static $timingStart = 0;
|
|
|
|
public function __construct(string $name){
|
|
parent::__construct(
|
|
$name,
|
|
"%pocketmine.command.timings.description",
|
|
"%pocketmine.command.timings.usage"
|
|
);
|
|
$this->setPermission("pocketmine.command.timings");
|
|
}
|
|
|
|
public function execute(CommandSender $sender, string $commandLabel, array $args){
|
|
if(!$this->testPermission($sender)){
|
|
return true;
|
|
}
|
|
|
|
if(count($args) !== 1){
|
|
throw new InvalidCommandSyntaxException();
|
|
}
|
|
|
|
$mode = strtolower($args[0]);
|
|
|
|
if($mode === "on"){
|
|
$sender->getServer()->getPluginManager()->setUseTimings(true);
|
|
TimingsHandler::reload();
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.enable"));
|
|
|
|
return true;
|
|
}elseif($mode === "off"){
|
|
$sender->getServer()->getPluginManager()->setUseTimings(false);
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.disable"));
|
|
return true;
|
|
}
|
|
|
|
if(!$sender->getServer()->getPluginManager()->useTimings()){
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.timingsDisabled"));
|
|
|
|
return true;
|
|
}
|
|
|
|
$paste = $mode === "paste";
|
|
|
|
if($mode === "reset"){
|
|
TimingsHandler::reload();
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.reset"));
|
|
}elseif($mode === "merged" or $mode === "report" or $paste){
|
|
|
|
$sampleTime = microtime(true) - self::$timingStart;
|
|
$index = 0;
|
|
$timingFolder = $sender->getServer()->getDataPath() . "timings/";
|
|
|
|
if(!file_exists($timingFolder)){
|
|
mkdir($timingFolder, 0777);
|
|
}
|
|
$timings = $timingFolder . "timings.txt";
|
|
while(file_exists($timings)){
|
|
$timings = $timingFolder . "timings" . (++$index) . ".txt";
|
|
}
|
|
|
|
$fileTimings = $paste ? fopen("php://temp", "r+b") : fopen($timings, "a+b");
|
|
|
|
TimingsHandler::printTimings($fileTimings);
|
|
|
|
fwrite($fileTimings, "Sample time " . round($sampleTime * 1000000000) . " (" . $sampleTime . "s)" . PHP_EOL);
|
|
|
|
if($paste){
|
|
fseek($fileTimings, 0);
|
|
$data = [
|
|
"syntax" => "text",
|
|
"poster" => $sender->getServer()->getName(),
|
|
"content" => stream_get_contents($fileTimings)
|
|
];
|
|
fclose($fileTimings);
|
|
|
|
$sender->getServer()->getScheduler()->scheduleAsyncTask(new class([
|
|
["page" => "http://paste.ubuntu.com", "extraOpts" => [
|
|
CURLOPT_HTTPHEADER => ["User-Agent: " . $sender->getServer()->getName() . " " . $sender->getServer()->getPocketMineVersion()],
|
|
CURLOPT_POST => 1,
|
|
CURLOPT_POSTFIELDS => $data
|
|
]]
|
|
], $sender) extends BulkCurlTask{
|
|
public function onCompletion(Server $server){
|
|
$sender = $this->fetchLocal($server);
|
|
if($sender instanceof Player and !$sender->isOnline()){ // TODO replace with a more generic API method for checking availability of CommandSender
|
|
return;
|
|
}
|
|
$result = $this->getResult()[0];
|
|
if($result instanceof \RuntimeException){
|
|
$server->getLogger()->logException($result);
|
|
return;
|
|
}
|
|
list(, $headers) = $result;
|
|
foreach($headers as $headerGroup){
|
|
if(isset($headerGroup["location"]) and preg_match('#^http://paste\\.ubuntu\\.com/([0-9]{1,})/#', trim($headerGroup["location"]), $match)){
|
|
$pasteId = $match[1];
|
|
break;
|
|
}
|
|
}
|
|
if(isset($pasteId)){
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.timingsUpload", ["http://paste.ubuntu.com/" . $pasteId . "/"]));
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.timingsRead",
|
|
["http://" . $sender->getServer()->getProperty("timings.host", "timings.pmmp.io") . "/?url=$pasteId"]));
|
|
}else{
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.pasteError"));
|
|
}
|
|
}
|
|
});
|
|
|
|
}else{
|
|
fclose($fileTimings);
|
|
$sender->sendMessage(new TranslationContainer("pocketmine.command.timings.timingsWrite", [$timings]));
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|