127 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace ManiaControl\Server;
 | |
| 
 | |
| use ManiaControl\Callbacks\CallbackListener;
 | |
| use ManiaControl\Callbacks\CallbackManager;
 | |
| use ManiaControl\Files\FileUtil;
 | |
| use ManiaControl\General\UsageInformationAble;
 | |
| use ManiaControl\General\UsageInformationTrait;
 | |
| use ManiaControl\ManiaControl;
 | |
| 
 | |
| /**
 | |
|  * Class offering Operations for the Server Directory
 | |
|  *
 | |
|  * @author    ManiaControl Team <mail@maniacontrol.com>
 | |
|  * @copyright 2014-2020 ManiaControl Team
 | |
|  * @license   http://www.gnu.org/licenses/ GNU General Public License, Version 3
 | |
|  */
 | |
| class Directory implements CallbackListener, UsageInformationAble {
 | |
| 	use UsageInformationTrait;
 | |
| 
 | |
| 	/*
 | |
| 	 * Private properties
 | |
| 	 */
 | |
| 	/** @var ManiaControl $maniaControl */
 | |
| 	private $maniaControl = null;
 | |
| 
 | |
| 	/**
 | |
| 	 * Construct new server directory instance
 | |
| 	 *
 | |
| 	 * @param ManiaControl $maniaControl
 | |
| 	 */
 | |
| 	public function __construct(ManiaControl $maniaControl) {
 | |
| 		$this->maniaControl = $maniaControl;
 | |
| 
 | |
| 		// Callbacks
 | |
| 		$this->maniaControl->getCallbackManager()->registerCallbackListener(CallbackManager::CB_MP_SERVERSTOP, $this, 'handleServerStopCallback');
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Retrieve the Maps Folder Path
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getMapsFolder() {
 | |
| 		return $this->maniaControl->getClient()->getMapsDirectory();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Retrieve the Skins Folder Path
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getSkinsFolder() {
 | |
| 		return $this->maniaControl->getClient()->getSkinsDirectory();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Handle Server Stop Callback
 | |
| 	 */
 | |
| 	public function handleServerStopCallback() {
 | |
| 		$this->cleanLogsFolder();
 | |
| 		$this->cleanCacheFolder();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Clean the server logs folder
 | |
| 	 *
 | |
| 	 * @return bool
 | |
| 	 */
 | |
| 	private function cleanLogsFolder() {
 | |
| 		return FileUtil::cleanDirectory($this->getLogsFolder());
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Retrieve the Logs Folder Path
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getLogsFolder() {
 | |
| 		return $this->getUserDataFolder() . '..' . DIRECTORY_SEPARATOR . 'Logs' . DIRECTORY_SEPARATOR;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Retrieve the GameData Folder Path
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getGameDataFolder(){
 | |
| 		return $this->getUserDataFolder() . '..' . DIRECTORY_SEPARATOR . 'GameData' . DIRECTORY_SEPARATOR;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Retrieve the User Data Folder Path
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getUserDataFolder() {
 | |
| 		return $this->maniaControl->getClient()->gameDataDirectory();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Retrieve the Scripts Folder Path
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getScriptsFolder(){
 | |
| 		return $this->getGameDataFolder() . 'Scripts'  . DIRECTORY_SEPARATOR;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * @return bool
 | |
| 	 */
 | |
| 	private function cleanCacheFolder() {
 | |
| 		return FileUtil::cleanDirectory($this->getCacheFolder(), 50);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Retrieve the Cache Folder Path
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getCacheFolder() {
 | |
| 		return $this->getUserDataFolder() . '..' . DIRECTORY_SEPARATOR . 'CommonData' . DIRECTORY_SEPARATOR . 'Cache' . DIRECTORY_SEPARATOR;
 | |
| 	}
 | |
| }
 |