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();
+	}
 }