X-Git-Url: https://git.rapsys.eu/airbundle/blobdiff_plain/b80a4b93b61544e110af7dcd2e40e4c95863a82e..e83f85c13afccface76993878f36f581b055a2fb:/DependencyInjection/RapsysAirExtension.php?ds=sidebyside diff --git a/DependencyInjection/RapsysAirExtension.php b/DependencyInjection/RapsysAirExtension.php index b901006..b09b135 100644 --- a/DependencyInjection/RapsysAirExtension.php +++ b/DependencyInjection/RapsysAirExtension.php @@ -1,20 +1,57 @@ - + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ namespace Rapsys\AirBundle\DependencyInjection; use Symfony\Component\DependencyInjection\ContainerBuilder; 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. * * @link http://symfony.com/doc/current/cookbook/bundles/extension.html */ -class RapsysAirExtension extends Extension { +class RapsysAirExtension extends Extension implements PrependExtensionInterface { /** * {@inheritdoc} + * + * Prepend the configuration + * + * Preload the configuration to allow sourcing as parameters */ - public function load(array $configs, ContainerBuilder $container) { + public function prepend(ContainerBuilder $container): void { + /*Load rapsysuser configurations + $rapsysusers = $container->getExtensionConfig($alias = RapsysUserBundle::getAlias()); + + //Recursively merge rapsysuser configurations + $rapsysuser = array_reduce( + $rapsysusers, + function ($res, $i) { + return array_merge_recursive($res, $i); + }, + [] + ); + + //Set rapsysuser.languages key + $container->setParameter($alias, $rapsysuser);*/ + + //Process the configuration + $configs = $container->getExtensionConfig($alias = RapsysAirBundle::getAlias()); + //Load configuration $configuration = $this->getConfiguration($configs, $container); @@ -24,17 +61,69 @@ class RapsysAirExtension extends Extension { //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 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); + } + + //Set rapsysair.alias key + $container->setParameter($alias.'.alias', $alias); + + //Set rapsysair.version key + $container->setParameter($alias.'.version', RapsysAirBundle::getVersion()); + } + + /** + * {@inheritdoc} + */ + public function load(array $configs, ContainerBuilder $container): void { + } + + /** + * The function that parses the array to flatten it into a one level depth array + * + * @param $array The config values array + * @param $path The current key path + * @param $depth The maxmium depth + * @param $sep The separator string + * @param $skip The skipped paths array + */ + protected function flatten($array, $path = '', $depth = 10, $sep = '.', $skip = []) { + //Init res + $res = array(); + + //Detect numerical only array + //count(array_filter($array, function($k) { return !is_numeric($k); }, ARRAY_FILTER_USE_KEY)) == 0 + //array_reduce(array_keys($array), function($c, $k) { return $c += !is_numeric($k); }, 0) + + //Flatten hashed array until depth reach zero + if ($depth && is_array($array) && $array !== [] && !in_array($path, $skip)) { + foreach($array as $k => $v) { + $sub = $path ? $path.$sep.$k:$k; + $res += $this->flatten($v, $sub, $depth - 1, $sep, $skip); + } + //Pass scalar value directly + } else { + $res[$path] = $array; + } + + //Return result + return $res; } /** * {@inheritdoc} + * + * @xxx Required by kernel to load renamed alias configuration */ - public function getAlias() { - return 'rapsys_air'; + public function getAlias(): string { + return RapsysAirBundle::getAlias(); } }