X-Git-Url: https://git.rapsys.eu/packbundle/blobdiff_plain/08334ace1c75289049baf0fd690deb983d6f1922..3651a34271af5d853c5cf09f0b9cfc3c4ce30d3e:/DependencyInjection/RapsysPackExtension.php diff --git a/DependencyInjection/RapsysPackExtension.php b/DependencyInjection/RapsysPackExtension.php index 5397036..c3b4a3b 100644 --- a/DependencyInjection/RapsysPackExtension.php +++ b/DependencyInjection/RapsysPackExtension.php @@ -3,9 +3,7 @@ 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; /** * This is the class that loads and manages your bundle configuration. @@ -17,25 +15,34 @@ 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'); - //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]); + //Detect when no user configuration is provided + if ($configs === [[]]) { + //Prepend default config + $container->prependExtensionConfig($this->getAlias(), $config); } + + //Save configuration in parameters + $container->setParameter($this->getAlias(), $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/'); + //Get configuration instance with resolved public path + return new Configuration($container->getParameter('kernel.project_dir').'/public/'); + } + + /** + * {@inheritdoc} + */ + public function getAlias() { + return 'rapsys_pack'; } }