X-Git-Url: https://git.rapsys.eu/packbundle/blobdiff_plain/e3ea38209d18dc220067e27b526dbff7cc838670..3bc9a721a4d6aaa777029a064fb48eb6f568e4e6:/DependencyInjection/RapsysPackExtension.php diff --git a/DependencyInjection/RapsysPackExtension.php b/DependencyInjection/RapsysPackExtension.php index 7d66000..3a6ed53 100644 --- a/DependencyInjection/RapsysPackExtension.php +++ b/DependencyInjection/RapsysPackExtension.php @@ -1,48 +1,70 @@ - + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rapsys\PackBundle\DependencyInjection; +use Rapsys\PackBundle\RapsysPackBundle; + 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; /** * 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(__DIR__.'/../Resources/config')); - $loader->load('services.yml'); - + 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]); + //Set bundle alias + $alias = RapsysPackBundle::getAlias(); + + //Detect when no user configuration is provided + if ($configs === [[]]) { + //Prepend default config + $container->prependExtensionConfig($alias, $config); } - } - /** - * {@inheritdoc} - */ - public function getConfiguration(array $configs, ContainerBuilder $container) { - //Get configuration instance with resolved web path - return new Configuration($container->getParameter('kernel.project_dir').'/web/'); + //Save configuration in parameters + $container->setParameter($alias, $config); + + //Set rapsyspack.alias key + $container->setParameter($alias.'.alias', $alias); + + //Set rapsyspack.cache key + $container->setParameter($alias.'.cache', $config['cache']); + + //Set rapsyspack.public key + $container->setParameter($alias.'.public', $config['public']); + + //Set rapsyspack.version key + $container->setParameter($alias.'.version', RapsysPackBundle::getVersion()); } /** * {@inheritdoc} + * + * @xxx Required by kernel to load renamed alias configuration */ - public function getAlias() { - return 'rapsys_pack'; + public function getAlias(): string { + return RapsysPackBundle::getAlias(); } }