diff options
Diffstat (limited to 'phpBB/phpbb/extension/metadata_manager.php')
| -rw-r--r-- | phpBB/phpbb/extension/metadata_manager.php | 138 | 
1 files changed, 44 insertions, 94 deletions
| diff --git a/phpBB/phpbb/extension/metadata_manager.php b/phpBB/phpbb/extension/metadata_manager.php index 107907609b..a09f07bed2 100644 --- a/phpBB/phpbb/extension/metadata_manager.php +++ b/phpBB/phpbb/extension/metadata_manager.php @@ -66,17 +66,18 @@ class metadata_manager  	*/  	protected $metadata_file; +	// @codingStandardsIgnoreStart  	/**  	* Creates the metadata manager  	*  	* @param string				$ext_name			Name (including vendor) of the extension  	* @param \phpbb\config\config		$config				phpBB Config instance  	* @param \phpbb\extension\manager	$extension_manager	An instance of the phpBB extension manager -	* @param \phpbb\template\template	$template			phpBB Template instance +	* @param \phpbb\template\template	$template			phpBB Template instance or null  	* @param \phpbb\user 		$user 				User instance  	* @param string				$phpbb_root_path	Path to the phpbb includes directory.  	*/ -	public function __construct($ext_name, \phpbb\config\config $config, \phpbb\extension\manager $extension_manager, \phpbb\template\template $template, \phpbb\user $user, $phpbb_root_path) +	public function __construct($ext_name, \phpbb\config\config $config, \phpbb\extension\manager $extension_manager, \phpbb\template\template $template = null, \phpbb\user $user, $phpbb_root_path)  	{  		$this->config = $config;  		$this->extension_manager = $extension_manager; @@ -88,6 +89,7 @@ class metadata_manager  		$this->metadata = array();  		$this->metadata_file = '';  	} +	// @codingStandardsIgnoreEnd  	/**  	* Processes and gets the metadata requested @@ -97,51 +99,38 @@ class metadata_manager  	*/  	public function get_metadata($element = 'all')  	{ -		$this->set_metadata_file(); - -		// Fetch the metadata -		$this->fetch_metadata(); - -		// Clean the metadata -		$this->clean_metadata_array(); +		// Fetch and clean the metadata if not done yet +		if ($this->metadata_file === '') +		{ +			$this->fetch_metadata_from_file(); +		}  		switch ($element)  		{  			case 'all':  			default: -				// Validate the metadata -				if (!$this->validate()) -				{ -					return false; -				} - +				$this->validate();  				return $this->metadata;  			break;  			case 'version':  			case 'name': -				return ($this->validate($element)) ? $this->metadata[$element] : false; +				$this->validate($element); +				return $this->metadata[$element];  			break;  			case 'display-name': -				if (isset($this->metadata['extra']['display-name'])) -				{ -					return $this->metadata['extra']['display-name']; -				} -				else -				{ -					return ($this->validate('name')) ? $this->metadata['name'] : false; -				} +				return (isset($this->metadata['extra']['display-name'])) ? $this->metadata['extra']['display-name'] : $this->get_metadata('name');  			break;  		}  	}  	/** -	* Sets the filepath of the metadata file +	* Sets the path of the metadata file, gets its contents and cleans loaded file  	*  	* @throws \phpbb\extension\exception  	*/ -	private function set_metadata_file() +	private function fetch_metadata_from_file()  	{  		$ext_filepath = $this->extension_manager->get_extension_path($this->ext_name);  		$metadata_filepath = $this->phpbb_root_path . $ext_filepath . 'composer.json'; @@ -152,37 +141,19 @@ class metadata_manager  		{  			throw new \phpbb\extension\exception($this->user->lang('FILE_NOT_FOUND', $this->metadata_file));  		} -	} -	/** -	* Gets the contents of the composer.json file -	* -	* @return bool True if success, throws an exception on failure -	* @throws \phpbb\extension\exception -	*/ -	private function fetch_metadata() -	{ -		if (!file_exists($this->metadata_file)) +		if (!($file_contents = file_get_contents($this->metadata_file)))  		{ -			throw new \phpbb\extension\exception($this->user->lang('FILE_NOT_FOUND', $this->metadata_file)); +			throw new \phpbb\extension\exception($this->user->lang('FILE_CONTENT_ERR', $this->metadata_file));  		} -		else -		{ -			if (!($file_contents = file_get_contents($this->metadata_file))) -			{ -				throw new \phpbb\extension\exception($this->user->lang('FILE_CONTENT_ERR', $this->metadata_file)); -			} - -			if (($metadata = json_decode($file_contents, true)) === null) -			{ -				throw new \phpbb\extension\exception($this->user->lang('FILE_JSON_DECODE_ERR', $this->metadata_file)); -			} -			array_walk_recursive($metadata, array($this, 'sanitize_json')); -			$this->metadata = $metadata; - -			return true; +		if (($metadata = json_decode($file_contents, true)) === null) +		{ +			throw new \phpbb\extension\exception($this->user->lang('FILE_JSON_DECODE_ERR', $this->metadata_file));  		} + +		array_walk_recursive($metadata, array($this, 'sanitize_json')); +		$this->metadata = $metadata;  	}  	/** @@ -197,16 +168,6 @@ class metadata_manager  	}  	/** -	* This array handles the cleaning of the array -	* -	* @return array Contains the cleaned metadata array -	*/ -	private function clean_metadata_array() -	{ -		return $this->metadata; -	} - -	/**  	* Validate fields  	*  	* @param string $name  ("all" for display and enable validation @@ -228,23 +189,8 @@ class metadata_manager  		switch ($name)  		{  			case 'all': -				$this->validate('display'); - -				if (!$this->validate_dir()) -				{ -					throw new \phpbb\extension\exception($this->user->lang('EXTENSION_DIR_INVALID')); -				} - -				if (!$this->validate_require_phpbb()) -				{ -					throw new \phpbb\extension\exception($this->user->lang('META_FIELD_NOT_SET', 'soft-require')); -				} - -				if (!$this->validate_require_php()) -				{ -					throw new \phpbb\extension\exception($this->user->lang('META_FIELD_NOT_SET', 'require php')); -				} -			break; +				$this->validate_enable(); +				// no break  			case 'display':  				foreach ($fields as $field => $data) @@ -301,40 +247,43 @@ class metadata_manager  	/**  	* This array handles the verification that this extension can be enabled on this board  	* -	* @return bool True if validation succeeded, False if failed +	* @return bool True if validation succeeded, throws an exception if invalid +	* @throws \phpbb\extension\exception  	*/  	public function validate_enable()  	{  		// Check for valid directory & phpBB, PHP versions -		if (!$this->validate_dir() || !$this->validate_require_phpbb() || !$this->validate_require_php()) -		{ -			return false; -		} - -		return true; +		return $this->validate_dir() && $this->validate_require_phpbb() && $this->validate_require_php();  	}  	/**  	* Validates the most basic directory structure to ensure it follows <vendor>/<ext> convention.  	* -	* @return boolean True when passes validation +	* @return boolean True when passes validation, throws an exception if invalid +	* @throws \phpbb\extension\exception  	*/  	public function validate_dir()  	{ -		return (substr_count($this->ext_name, '/') === 1 && $this->ext_name == $this->get_metadata('name')); +		if (substr_count($this->ext_name, '/') !== 1 || $this->ext_name != $this->get_metadata('name')) +		{ +			throw new \phpbb\extension\exception($this->user->lang('EXTENSION_DIR_INVALID')); +		} + +		return true;  	}  	/**  	* Validates the contents of the phpbb requirement field  	* -	* @return boolean True when passes validation +	* @return boolean True when passes validation, throws an exception if invalid +	* @throws \phpbb\extension\exception  	*/  	public function validate_require_phpbb()  	{  		if (!isset($this->metadata['extra']['soft-require']['phpbb/phpbb']))  		{ -			return false; +			throw new \phpbb\extension\exception($this->user->lang('META_FIELD_NOT_SET', 'soft-require'));  		}  		return true; @@ -343,13 +292,14 @@ class metadata_manager  	/**  	* Validates the contents of the php requirement field  	* -	* @return boolean True when passes validation +	* @return boolean True when passes validation, throws an exception if invalid +	* @throws \phpbb\extension\exception  	*/  	public function validate_require_php()  	{  		if (!isset($this->metadata['require']['php']))  		{ -			return false; +			throw new \phpbb\extension\exception($this->user->lang('META_FIELD_NOT_SET', 'require php'));  		}  		return true; @@ -372,10 +322,10 @@ class metadata_manager  			'META_LICENSE'		=> $this->metadata['license'],  			'META_REQUIRE_PHP'		=> (isset($this->metadata['require']['php'])) ? $this->metadata['require']['php'] : '', -			'META_REQUIRE_PHP_FAIL'	=> !$this->validate_require_php(), +			'META_REQUIRE_PHP_FAIL'	=> (isset($this->metadata['require']['php'])) ? false : true,  			'META_REQUIRE_PHPBB'		=> (isset($this->metadata['extra']['soft-require']['phpbb/phpbb'])) ? $this->metadata['extra']['soft-require']['phpbb/phpbb'] : '', -			'META_REQUIRE_PHPBB_FAIL'	=> !$this->validate_require_phpbb(), +			'META_REQUIRE_PHPBB_FAIL'	=> (isset($this->metadata['extra']['soft-require']['phpbb/phpbb'])) ? false : true,  			'META_DISPLAY_NAME'	=> (isset($this->metadata['extra']['display-name'])) ? $this->metadata['extra']['display-name'] : '',  		)); | 
