mirror of
https://github.com/phpbb/phpbb.git
synced 2025-07-30 21:40:43 +02:00
[ticket/12620] Adds a yaml config file
PHPBB3-12620
This commit is contained in:
38
phpBB/phpbb/di/extension/container_configuration.php
Normal file
38
phpBB/phpbb/di/extension/container_configuration.php
Normal file
@@ -0,0 +1,38 @@
|
||||
<?php
|
||||
/**
|
||||
*
|
||||
* This file is part of the phpBB Forum Software package.
|
||||
*
|
||||
* @copyright (c) phpBB Limited <https://www.phpbb.com>
|
||||
* @license GNU General Public License, version 2 (GPL-2.0)
|
||||
*
|
||||
* For full copyright and license information, please see
|
||||
* the docs/CREDITS.txt file.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace phpbb\di\extension;
|
||||
|
||||
use Symfony\Component\Config\Definition\Builder\TreeBuilder;
|
||||
use Symfony\Component\Config\Definition\ConfigurationInterface;
|
||||
|
||||
class container_configuration implements ConfigurationInterface
|
||||
{
|
||||
|
||||
/**
|
||||
* Generates the configuration tree builder.
|
||||
*
|
||||
* @return \Symfony\Component\Config\Definition\Builder\TreeBuilder The tree builder
|
||||
*/
|
||||
public function getConfigTreeBuilder()
|
||||
{
|
||||
$treeBuilder = new TreeBuilder();
|
||||
$rootNode = $treeBuilder->root('core');
|
||||
$rootNode
|
||||
->children()
|
||||
->booleanNode('require_dev_dependencies')->defaultValue(false)->end()
|
||||
->end()
|
||||
;
|
||||
return $treeBuilder;
|
||||
}
|
||||
}
|
@@ -13,10 +13,11 @@
|
||||
|
||||
namespace phpbb\di\extension;
|
||||
|
||||
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
||||
use Symfony\Component\HttpKernel\DependencyInjection\Extension;
|
||||
use Symfony\Component\DependencyInjection\Loader\YamlFileLoader;
|
||||
use Symfony\Component\Config\FileLocator;
|
||||
use Symfony\Component\Config\Resource\FileResource;
|
||||
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
||||
use Symfony\Component\DependencyInjection\Loader\YamlFileLoader;
|
||||
use Symfony\Component\HttpKernel\DependencyInjection\Extension;
|
||||
|
||||
/**
|
||||
* Container core extension
|
||||
@@ -42,15 +43,41 @@ class core extends Extension
|
||||
/**
|
||||
* Loads a specific configuration.
|
||||
*
|
||||
* @param array $config An array of configuration values
|
||||
* @param array $configs 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)
|
||||
public function load(array $configs, ContainerBuilder $container)
|
||||
{
|
||||
$loader = new YamlFileLoader($container, new FileLocator(phpbb_realpath($this->config_path)));
|
||||
$loader->load(PHPBB_ENVIRONMENT . '/environment.yml');
|
||||
$loader->load(PHPBB_ENVIRONMENT . '/container/environment.yml');
|
||||
|
||||
$config = $this->getConfiguration($configs, $container);
|
||||
$config = $this->processConfiguration($config, $configs);
|
||||
|
||||
if ($config['require_dev_dependencies'])
|
||||
{
|
||||
if (!class_exists('Goutte\Client', true))
|
||||
{
|
||||
trigger_error(
|
||||
'Composer development dependencies have not been set up for the ' . $container->getParameter('core.environment') . ' environment yet, run ' .
|
||||
"'php ../composer.phar install --dev' from the phpBB directory to do so.",
|
||||
E_USER_ERROR
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function getConfiguration(array $config, ContainerBuilder $container)
|
||||
{
|
||||
$r = new \ReflectionClass('\phpbb\di\extension\container_configuration');
|
||||
$container->addResource(new FileResource($r->getFileName()));
|
||||
|
||||
return new container_configuration();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@@ -48,16 +48,16 @@ class ext extends Extension
|
||||
$services_directory = false;
|
||||
$services_file = false;
|
||||
|
||||
if (file_exists($path . 'config/' . PHPBB_ENVIRONMENT . '/environment.yml'))
|
||||
if (file_exists($path . 'config/' . PHPBB_ENVIRONMENT . '/container/environment.yml'))
|
||||
{
|
||||
$services_directory = $path . 'config/' . PHPBB_ENVIRONMENT;
|
||||
$services_directory = $path . 'config/' . PHPBB_ENVIRONMENT . '/container/';
|
||||
$services_file = 'environment.yml';
|
||||
}
|
||||
else if (!is_dir($path . 'config/' . PHPBB_ENVIRONMENT))
|
||||
{
|
||||
if (file_exists($path . 'config/default/environment.yml'))
|
||||
if (file_exists($path . 'config/default/container/environment.yml'))
|
||||
{
|
||||
$services_directory = $path . 'config/default';
|
||||
$services_directory = $path . 'config/default/container/';
|
||||
$services_file = 'environment.yml';
|
||||
}
|
||||
else if (!is_dir($path . 'config/default') && file_exists($path . '/config/services.yml'))
|
||||
|
Reference in New Issue
Block a user