diff options
Diffstat (limited to 'phpBB/phpbb/di/extension')
| -rw-r--r-- | phpBB/phpbb/di/extension/config.php | 86 | ||||
| -rw-r--r-- | phpBB/phpbb/di/extension/core.php | 71 | ||||
| -rw-r--r-- | phpBB/phpbb/di/extension/ext.php | 71 | 
3 files changed, 228 insertions, 0 deletions
diff --git a/phpBB/phpbb/di/extension/config.php b/phpBB/phpbb/di/extension/config.php new file mode 100644 index 0000000000..85b374a3ca --- /dev/null +++ b/phpBB/phpbb/di/extension/config.php @@ -0,0 +1,86 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +namespace phpbb\di\extension; + +/** +* @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 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/phpbb/di/extension/core.php b/phpBB/phpbb/di/extension/core.php new file mode 100644 index 0000000000..1f6b700973 --- /dev/null +++ b/phpBB/phpbb/di/extension/core.php @@ -0,0 +1,71 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +namespace phpbb\di\extension; + +/** +* @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 core extends Extension +{ +	/** +	* Config path +	* @var string +	*/ +	protected $config_path; + +	/** +	* Constructor +	* +	* @param string $config_path Config path +	*/ +	public function __construct($config_path) +	{ +		$this->config_path = $config_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->config_path))); +		$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/phpbb/di/extension/ext.php b/phpBB/phpbb/di/extension/ext.php new file mode 100644 index 0000000000..cf623a7c87 --- /dev/null +++ b/phpBB/phpbb/di/extension/ext.php @@ -0,0 +1,71 @@ +<?php +/** +* +* @package phpBB3 +* @copyright (c) 2012 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +namespace phpbb\di\extension; + +/** +* @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 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'; +	} +}  | 
