X-Git-Url: https://git.rapsys.eu/airbundle/blobdiff_plain/28d443906d7ec95c43bd570f8fe666a28aefbacf..5bdc01337b213b789f58b3a02596688082cfc129:/DependencyInjection/RapsysAirExtension.php diff --git a/DependencyInjection/RapsysAirExtension.php b/DependencyInjection/RapsysAirExtension.php index e00159b..b09b135 100644 --- a/DependencyInjection/RapsysAirExtension.php +++ b/DependencyInjection/RapsysAirExtension.php @@ -1,4 +1,13 @@ -<?php +<?php declare(strict_types=1); + +/* + * This file is part of the Rapsys PackBundle package. + * + * (c) Raphaël Gertz <symfony@rapsys.eu> + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rapsys\AirBundle\DependencyInjection; @@ -7,6 +16,10 @@ use Symfony\Component\DependencyInjection\Extension\Extension; use Symfony\Component\DependencyInjection\Extension\PrependExtensionInterface; use Symfony\Component\Translation\Loader\ArrayLoader; +use Rapsys\AirBundle\RapsysAirBundle; + +use Rapsys\UserBundle\RapsysUserBundle; + /** * This is the class that loads and manages your bundle configuration. * @@ -14,49 +27,30 @@ use Symfony\Component\Translation\Loader\ArrayLoader; */ class RapsysAirExtension extends Extension implements PrependExtensionInterface { /** + * {@inheritdoc} + * * Prepend the configuration * - * @desc Preload the configuration to allow sourcing as parameters - * {@inheritdoc} + * Preload the configuration to allow sourcing as parameters */ - public function prepend(ContainerBuilder $container) { - //Load framework configurations - //XXX: required to extract default_locale and translation.fallbacks - $frameworks = $container->getExtensionConfig('framework'); - - //Recursively merge framework configurations - $framework = array_reduce( - $frameworks, - function ($res, $i) { - return array_merge_recursive($res, $i); - }, - [] - ); + public function prepend(ContainerBuilder $container): void { + /*Load rapsysuser configurations + $rapsysusers = $container->getExtensionConfig($alias = RapsysUserBundle::getAlias()); - //Set translator fallbacks - $container->setParameter('kernel.translator.fallbacks', $framework['translator']['fallbacks']); - - //Set default locale - $container->setParameter('kernel.default_locale', $framework['default_locale']); - - //Load rapsys_user configurations - //XXX: required to extract default_locale and translation.fallbacks - $rapsys_users = $container->getExtensionConfig('rapsys_user'); - - //Recursively merge rapsys_user configurations - $rapsys_user = array_reduce( - $rapsys_users, + //Recursively merge rapsysuser configurations + $rapsysuser = array_reduce( + $rapsysusers, function ($res, $i) { return array_merge_recursive($res, $i); }, [] ); - //Set rapsys_user.languages key - $container->setParameter('rapsys_user.languages', $rapsys_user['languages']); + //Set rapsysuser.languages key + $container->setParameter($alias, $rapsysuser);*/ //Process the configuration - $configs = $container->getExtensionConfig($this->getAlias()); + $configs = $container->getExtensionConfig($alias = RapsysAirBundle::getAlias()); //Load configuration $configuration = $this->getConfiguration($configs, $container); @@ -67,30 +61,29 @@ class RapsysAirExtension extends Extension implements PrependExtensionInterface //Detect when no user configuration is provided if ($configs === [[]]) { //Prepend default config - $container->prependExtensionConfig($this->getAlias(), $config); + $container->prependExtensionConfig($alias, $config); } //Save configuration in parameters - $container->setParameter($this->getAlias(), $config); + $container->setParameter($alias, $config); //Store flattened array in parameters - //XXX: don't flatten rapsys_air.site.png key which is required to be an array - foreach($this->flatten($config, $this->getAlias(), 10, '.', ['rapsys_air.site.png', 'rapsys_air.locales', 'rapsys_air.languages']) as $k => $v) { + //XXX: don't flatten rapsysair.site.png key which is required to be an array + foreach($this->flatten($config, $alias, 10, '.', ['rapsysair.copy', 'rapsysair.icon', 'rapsysair.icon.png', 'rapsysair.logo', 'rapsysair.facebook.apps', 'rapsysair.locales', 'rapsysair.languages']) as $k => $v) { $container->setParameter($k, $v); } - } - /** - * {@inheritdoc} - */ - public function load(array $configs, ContainerBuilder $container) { + //Set rapsysair.alias key + $container->setParameter($alias.'.alias', $alias); + + //Set rapsysair.version key + $container->setParameter($alias.'.version', RapsysAirBundle::getVersion()); } /** * {@inheritdoc} */ - public function getAlias() { - return 'rapsys_air'; + public function load(array $configs, ContainerBuilder $container): void { } /** @@ -124,4 +117,13 @@ class RapsysAirExtension extends Extension implements PrependExtensionInterface //Return result return $res; } + + /** + * {@inheritdoc} + * + * @xxx Required by kernel to load renamed alias configuration + */ + public function getAlias(): string { + return RapsysAirBundle::getAlias(); + } }