diff options
Diffstat (limited to 'phpBB/includes/di/extension')
| -rw-r--r-- | phpBB/includes/di/extension/config.php | 84 | ||||
| -rw-r--r-- | phpBB/includes/di/extension/core.php | 69 | ||||
| -rw-r--r-- | phpBB/includes/di/extension/ext.php | 69 | 
3 files changed, 222 insertions, 0 deletions
diff --git a/phpBB/includes/di/extension/config.php b/phpBB/includes/di/extension/config.php new file mode 100644 index 0000000000..6c272a6588 --- /dev/null +++ b/phpBB/includes/di/extension/config.php @@ -0,0 +1,84 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @ignore +*/ +if (!defined('IN_PHPBB')) +{ +	exit; +} + +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\HttpKernel\DependencyInjection\Extension; +use Symfony\Component\DependencyInjection\Loader\XmlFileLoader; +use Symfony\Component\Config\FileLocator; + +/** +* Container config extension +*/ +class phpbb_di_extension_config extends Extension +{ +	public function __construct($config_file) +	{ +		$this->config_file = $config_file; +	} + +	/** +	* Loads a specific configuration. +	* +	* @param array            $config    An array of configuration values +	* @param ContainerBuilder $container A ContainerBuilder instance +	* +	* @throws InvalidArgumentException When provided tag is not defined in this extension +	*/ +	public function load(array $config, ContainerBuilder $container) +	{ +		require($this->config_file); + +		$container->setParameter('core.adm_relative_path', (isset($phpbb_adm_relative_path) ? $phpbb_adm_relative_path : 'adm/')); +		$container->setParameter('core.table_prefix', $table_prefix); +		$container->setParameter('cache.driver.class', $this->convert_30_acm_type($acm_type)); +		$container->setParameter('dbal.driver.class', phpbb_convert_30_dbms_to_31($dbms)); +		$container->setParameter('dbal.dbhost', $dbhost); +		$container->setParameter('dbal.dbuser', $dbuser); +		$container->setParameter('dbal.dbpasswd', $dbpasswd); +		$container->setParameter('dbal.dbname', $dbname); +		$container->setParameter('dbal.dbport', $dbport); +		$container->setParameter('dbal.new_link', defined('PHPBB_DB_NEW_LINK') && PHPBB_DB_NEW_LINK); +	} + +	/** +	* Returns the recommended alias to use in XML. +	* +	* This alias is also the mandatory prefix to use when using YAML. +	* +	* @return string The alias +	*/ +	public function getAlias() +	{ +		return 'config'; +	} + +	/** +	* Convert 3.0 ACM type to 3.1 cache driver class name +	* +	* @param string $acm_type ACM type +	* @return cache driver class +	*/ +	protected function convert_30_acm_type($acm_type) +	{ +		if (preg_match('#^[a-z]+$#', $acm_type)) +		{ +			return 'phpbb_cache_driver_'.$acm_type; +		} + +		return $acm_type; +	} +} diff --git a/phpBB/includes/di/extension/core.php b/phpBB/includes/di/extension/core.php new file mode 100644 index 0000000000..9c36ba2fc4 --- /dev/null +++ b/phpBB/includes/di/extension/core.php @@ -0,0 +1,69 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @ignore +*/ +if (!defined('IN_PHPBB')) +{ +	exit; +} + +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\HttpKernel\DependencyInjection\Extension; +use Symfony\Component\DependencyInjection\Loader\YamlFileLoader; +use Symfony\Component\Config\FileLocator; + +/** +* Container core extension +*/ +class phpbb_di_extension_core extends Extension +{ +	/** +	* phpBB Root path +	* @var string +	*/ +	protected $root_path; + +	/** +	* Constructor +	* +	* @param string $root_path Root path +	*/ +	public function __construct($root_path) +	{ +		$this->root_path = $root_path; +	} + +	/** +	* Loads a specific configuration. +	* +	* @param array            $config    An array of configuration values +	* @param ContainerBuilder $container A ContainerBuilder instance +	* +	* @throws InvalidArgumentException When provided tag is not defined in this extension +	*/ +	public function load(array $config, ContainerBuilder $container) +	{ +		$loader = new YamlFileLoader($container, new FileLocator(phpbb_realpath($this->root_path . 'config'))); +		$loader->load('services.yml'); +	} + +	/** +	* Returns the recommended alias to use in XML. +	* +	* This alias is also the mandatory prefix to use when using YAML. +	* +	* @return string The alias +	*/ +	public function getAlias() +	{ +		return 'core'; +	} +} diff --git a/phpBB/includes/di/extension/ext.php b/phpBB/includes/di/extension/ext.php new file mode 100644 index 0000000000..7d9b433751 --- /dev/null +++ b/phpBB/includes/di/extension/ext.php @@ -0,0 +1,69 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +/** +* @ignore +*/ +if (!defined('IN_PHPBB')) +{ +	exit; +} + +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\HttpKernel\DependencyInjection\Extension; +use Symfony\Component\DependencyInjection\Loader\YamlFileLoader; +use Symfony\Component\Config\FileLocator; + +/** +* Container ext extension +*/ +class phpbb_di_extension_ext extends Extension +{ +	protected $paths = array(); + +	public function __construct($enabled_extensions) +	{ +		foreach ($enabled_extensions as $ext => $path) +		{ +			$this->paths[] = $path; +		} +	} + +	/** +	* Loads a specific configuration. +	* +	* @param array            $config    An array of configuration values +	* @param ContainerBuilder $container A ContainerBuilder instance +	* +	* @throws InvalidArgumentException When provided tag is not defined in this extension +	*/ +	public function load(array $config, ContainerBuilder $container) +	{ +		foreach ($this->paths as $path) +		{ +			if (file_exists($path . '/config/services.yml')) +			{ +				$loader = new YamlFileLoader($container, new FileLocator(phpbb_realpath($path . '/config'))); +				$loader->load('services.yml'); +			} +		} +	} + +	/** +	* Returns the recommended alias to use in XML. +	* +	* This alias is also the mandatory prefix to use when using YAML. +	* +	* @return string The alias +	*/ +	public function getAlias() +	{ +		return 'ext'; +	} +}  | 
