mirror of
				https://github.com/Matthww/PlayerInfo.git
				synced 2025-10-25 18:22:43 +00:00 
			
		
		
		
	Plugin fixed & improvements (#22)
* test * tes * - Fixes and improvements (click me) - Plugin works now properly - Fixed a bug where the player configuration file was not created - Now saves history when player connect, not only the last player's sessions * English translation and final corrections
This commit is contained in:
		| @@ -36,6 +36,8 @@ class PlayerInfo extends PluginBase implements Listener { | |||||||
|             $this->saveDefaultConfig(); |             $this->saveDefaultConfig(); | ||||||
|         } |         } | ||||||
|         $this->getServer()->getAsyncPool()->submitTask(new FetchModelsTask($this->getDataFolder(), $this->getDescription()->getVersion())); |         $this->getServer()->getAsyncPool()->submitTask(new FetchModelsTask($this->getDataFolder(), $this->getDescription()->getVersion())); | ||||||
|  |         // const $lokalizacja = $this->getDataFolder(); | ||||||
|  |          | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public function onPacketReceived(DataPacketReceiveEvent $receiveEvent) { |     public function onPacketReceived(DataPacketReceiveEvent $receiveEvent) { | ||||||
| @@ -48,9 +50,16 @@ class PlayerInfo extends PluginBase implements Listener { | |||||||
|     public function onJoin(PlayerJoinEvent $joinEvent) { |     public function onJoin(PlayerJoinEvent $joinEvent) { | ||||||
|         if($this->getConfig()->get("Save") == true) { |         if($this->getConfig()->get("Save") == true) { | ||||||
|             $player = $joinEvent->getPlayer(); |             $player = $joinEvent->getPlayer(); | ||||||
|             if (!in_array($player->getName(), $this->PlayerData)) { |             if(!is_dir($this->getDataFolder() . "players/".$player->getName())) { | ||||||
|                 return false; |                 $this->getLogger()->info(TF::YELLOW."[PLAYERINFODB] > User not found in db... adding."); | ||||||
|  |                 mkdir($this->getDataFolder() . "players/".$player->getName()); | ||||||
|             } |             } | ||||||
|  |             $this->getLogger()->info(TF::GREEN.'[PLAYERINFO] > Adding user session '.$player->getName()." to history"); | ||||||
|  |             date_default_timezone_set("Europe/Warsaw"); | ||||||
|  |             $date = date('m-d-Y_h-i-s_a', time());  // save date and time (Hours need to being separated with "-" too for windows system because it is crazy....) | ||||||
|  |             | ||||||
|  |             | ||||||
|  |           | ||||||
|             $cdata = $this->PlayerData[$player->getName()]; |             $cdata = $this->PlayerData[$player->getName()]; | ||||||
|             $os = ["Unknown", "Android", "iOS", "macOS", "FireOS", "GearVR", "HoloLens", "Windows 10", "Windows", "Dedicated", "Orbis", "Playstation 4", "Nintento Switch", "Xbox One"]; |             $os = ["Unknown", "Android", "iOS", "macOS", "FireOS", "GearVR", "HoloLens", "Windows 10", "Windows", "Dedicated", "Orbis", "Playstation 4", "Nintento Switch", "Xbox One"]; | ||||||
|             $UI = ["Classic UI", "Pocket UI"]; |             $UI = ["Classic UI", "Pocket UI"]; | ||||||
| @@ -59,6 +68,7 @@ class PlayerInfo extends PluginBase implements Listener { | |||||||
|              |              | ||||||
|             $this->getScheduler()->scheduleTask(new SaveTask( |             $this->getScheduler()->scheduleTask(new SaveTask( | ||||||
|                 $this, |                 $this, | ||||||
|  |                 $date, | ||||||
|                 $player->getName(), |                 $player->getName(), | ||||||
|                 $this->getModel($cdata["DeviceModel"]), |                 $this->getModel($cdata["DeviceModel"]), | ||||||
|                 $os[$cdata["DeviceOS"]], |                 $os[$cdata["DeviceOS"]], | ||||||
| @@ -66,7 +76,10 @@ class PlayerInfo extends PluginBase implements Listener { | |||||||
|                 $UI[$cdata["UIProfile"]], |                 $UI[$cdata["UIProfile"]], | ||||||
|                 $GUI[$cdata["GuiScale"]], |                 $GUI[$cdata["GuiScale"]], | ||||||
|                 $Controls[$cdata["CurrentInputMode"]] |                 $Controls[$cdata["CurrentInputMode"]] | ||||||
|  |                  | ||||||
|  |                  | ||||||
|             )); |             )); | ||||||
|  |              | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,11 +3,13 @@ namespace Matthww\PlayerInfo\Tasks; | |||||||
|  |  | ||||||
| use pocketmine\scheduler\Task; | use pocketmine\scheduler\Task; | ||||||
| use pocketmine\utils\Config; | use pocketmine\utils\Config; | ||||||
|  | use pocketmine\utils\TextFormat as TF; | ||||||
|  |  | ||||||
| class SaveTask extends Task { | class SaveTask extends Task { | ||||||
|  |  | ||||||
|     public $plugin; |     public $plugin; | ||||||
|      |      | ||||||
|  |     protected $date; | ||||||
|     protected $player; |     protected $player; | ||||||
|     protected $model; |     protected $model; | ||||||
|     protected $os; |     protected $os; | ||||||
| @@ -16,8 +18,9 @@ class SaveTask extends Task { | |||||||
|     protected $GUI; |     protected $GUI; | ||||||
|     protected $controls; |     protected $controls; | ||||||
|  |  | ||||||
|     public function __construct($plugin, string $player, string $model, string $os, string $ip, string $UI, string $GUI, string $controls) { |     public function __construct($plugin, string $date, string $player, string $model, string $os, string $ip, string $UI, string $GUI, string $controls) { | ||||||
|         $this->plugin = $plugin; |         $this->plugin = $plugin; | ||||||
|  |         $this->date = $date; | ||||||
|         $this->player = $player; |         $this->player = $player; | ||||||
|         $this->model = $model; |         $this->model = $model; | ||||||
|         $this->os = $os; |         $this->os = $os; | ||||||
| @@ -32,7 +35,8 @@ class SaveTask extends Task { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public function onRun(int $tick) { |     public function onRun(int $tick) { | ||||||
|         $data = new Config($this->getPlugin()->getDataFolder() . "players/" . strtolower($this->player) . ".json", Config::JSON); |         $data = new Config($this->getPlugin()->getDataFolder() . "players/" .$this->player."/". strtolower($this->player)."-".$this->date. ".json", Config::JSON); | ||||||
|  |         $data->set("Date", $this->date); | ||||||
|         $data->set("Name", $this->player); |         $data->set("Name", $this->player); | ||||||
|         $data->set("Model", $this->model); |         $data->set("Model", $this->model); | ||||||
|         $data->set("OS", $this->os); |         $data->set("OS", $this->os); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user