X-Git-Url: https://git.rapsys.eu/packbundle/blobdiff_plain/7a2bed7826daa04288eed02b303f6194f8908566..9d0a8f506d7b005236a693838ffefc655df2e39f:/DependencyInjection/RapsysPackExtension.php?ds=sidebyside diff --git a/DependencyInjection/RapsysPackExtension.php b/DependencyInjection/RapsysPackExtension.php index c844233..e1f1996 100644 --- a/DependencyInjection/RapsysPackExtension.php +++ b/DependencyInjection/RapsysPackExtension.php @@ -1,86 +1,59 @@ - + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rapsys\PackBundle\DependencyInjection; use Symfony\Component\DependencyInjection\ContainerBuilder; -use Symfony\Component\Config\FileLocator; -use Symfony\Component\HttpKernel\DependencyInjection\Extension; -use Symfony\Component\DependencyInjection\Loader; +use Symfony\Component\DependencyInjection\Extension\Extension; + +use Rapsys\PackBundle\RapsysPackBundle; /** * This is the class that loads and manages your bundle configuration. * * @link http://symfony.com/doc/current/cookbook/bundles/extension.html + * + * {@inheritdoc} */ class RapsysPackExtension extends Extension { /** * {@inheritdoc} */ - public function load(array $configs, ContainerBuilder $container) { - //Load configuration - #$loader = new Loader\YamlFileLoader($container, new FileLocator(\dirname(__DIR__).'/Resources/config')); - $loader = new Loader\YamlFileLoader($container, new FileLocator('config/packages')); - $loader->load($this->getAlias().'.yaml'); - + public function load(array $configs, ContainerBuilder $container): void { //Load configuration $configuration = $this->getConfiguration($configs, $container); + + //Process the configuration to get merged config $config = $this->processConfiguration($configuration, $configs); - //Set default config in parameter - if (!$container->hasParameter($alias = $this->getAlias())) { - $container->setParameter($alias, $config[$alias]); - //Fill missing entries - } else { - //Change in config flag - $change = false; + //Detect when no user configuration is provided + if ($configs === [[]]) { + //Prepend default config + $container->prependExtensionConfig(self::getAlias(), $config); + } - //Iterate on each user configuration keys - foreach($container->getParameter($alias) as $k => $v) { - //Check if value is an array - if (is_array($v)) { - //Iterate on each array keys - foreach($v as $sk => $sv) { - //Check if sub value is an array - if (is_array($sv)) { - //TODO: implement sub sub key merging ? (or recursive ?) - @trigger_error('Nested level > 2 not yet implemented here', E_USER_ERROR); - //Save sub value - } else { - //Trigger changed flag - $change = true; - //Replace default value with user provided one - $config[$alias][$k][$sk] = $sv; - } - } - //Save value - } else { - //Trigger changed flag - $change = true; - //Replace default value with user provided one - $config[$alias][$k] = $v; - } - } + //Save configuration in parameters + $container->setParameter(self::getAlias(), $config); - //Check if change occured - if ($change) { - //Save parameters - $container->setParameter($alias, $config[$alias]); - } - } - } + //Set rapsys_pack.public.path key + $container->setParameter(self::getAlias().'.public.path', $config['public']['path']); - /** - * {@inheritdoc} - */ - public function getConfiguration(array $configs, ContainerBuilder $container) { - //Get configuration instance with resolved public path - return new Configuration($container->getParameter('kernel.project_dir').'/public/'); + //Set rapsys_pack.public.url key + $container->setParameter(self::getAlias().'.public.url', $config['public']['url']); } /** * {@inheritdoc} */ - public function getAlias() { - return 'rapsys_pack'; + public function getAlias(): string { + return RapsysPackBundle::getAlias(); } }