AsseticExtension.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <?php
  2. /*
  3. * This file is part of the Symfony framework.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * This source file is subject to the MIT license that is bundled
  8. * with this source code in the file LICENSE.
  9. */
  10. namespace Symfony\Bundle\AsseticBundle\DependencyInjection;
  11. use Symfony\Component\Config\FileLocator;
  12. use Symfony\Component\Config\Definition\Processor;
  13. use Symfony\Component\DependencyInjection\ContainerBuilder;
  14. use Symfony\Component\DependencyInjection\Definition;
  15. use Symfony\Component\DependencyInjection\Loader\XmlFileLoader;
  16. use Symfony\Component\DependencyInjection\Reference;
  17. use Symfony\Component\HttpKernel\DependencyInjection\Extension;
  18. /**
  19. * Semantic asset configuration.
  20. *
  21. * @author Kris Wallsmith <kris@symfony.com>
  22. */
  23. class AsseticExtension extends Extension
  24. {
  25. /**
  26. * Loads the configuration.
  27. *
  28. * @param array $configs An array of configuration settings
  29. * @param ContainerBuilder $container A ContainerBuilder instance
  30. */
  31. public function load(array $configs, ContainerBuilder $container)
  32. {
  33. $parameterBag = $container->getParameterBag();
  34. $loader = new XmlFileLoader($container, new FileLocator(__DIR__ . '/../Resources/config'));
  35. $loader->load('assetic.xml');
  36. $loader->load('templating_twig.xml');
  37. $loader->load('templating_php.xml');
  38. $config = self::processConfigs($configs, $container->getParameter('kernel.debug'), array_keys($container->getParameter('kernel.bundles')));
  39. $container->setParameter('assetic.debug', $config['debug']);
  40. $container->setParameter('assetic.use_controller', $config['use_controller']);
  41. $container->setParameter('assetic.read_from', $config['read_from']);
  42. $container->setParameter('assetic.write_to', $config['write_to']);
  43. $container->setParameter('assetic.java.bin', $config['java']);
  44. $container->setParameter('assetic.node.bin', $config['node']);
  45. $container->setParameter('assetic.sass.bin', $config['sass']);
  46. // register filters
  47. foreach ($config['filters'] as $name => $filter) {
  48. if (isset($filter['resource'])) {
  49. $loader->load($parameterBag->resolveValue($filter['resource']));
  50. unset($filter['resource']);
  51. } else {
  52. $loader->load('filters/'.$name.'.xml');
  53. }
  54. if (isset($filter['file'])) {
  55. $container->getDefinition('assetic.filter.'.$name)->setFile($filter['file']);
  56. unset($filter['file']);
  57. }
  58. foreach ($filter as $key => $value) {
  59. $container->setParameter('assetic.filter.'.$name.'.'.$key, $value);
  60. }
  61. }
  62. // twig functions
  63. $container->getDefinition('assetic.twig_extension')->replaceArgument(2, $config['twig']['functions']);
  64. // choose dynamic or static
  65. if ($parameterBag->resolveValue($parameterBag->get('assetic.use_controller'))) {
  66. $loader->load('controller.xml');
  67. $container->getDefinition('assetic.helper.dynamic')->addTag('templating.helper', array('alias' => 'assetic'));
  68. $container->removeDefinition('assetic.helper.static');
  69. } else {
  70. $loader->load('asset_writer.xml');
  71. $container->getDefinition('assetic.helper.static')->addTag('templating.helper', array('alias' => 'assetic'));
  72. $container->removeDefinition('assetic.helper.dynamic');
  73. }
  74. // register config resources
  75. self::registerFormulaResources($container, $parameterBag->resolveValue($config['bundles']));
  76. }
  77. /**
  78. * Merges the user's config arrays.
  79. *
  80. * @param array $configs An array of config arrays
  81. * @param Boolean $debug The debug mode
  82. * @param array $bundles An array of all bundle names
  83. *
  84. * @return array The merged config
  85. */
  86. static protected function processConfigs(array $configs, $debug, array $bundles)
  87. {
  88. $processor = new Processor();
  89. $configuration = new Configuration($debug, $bundles);
  90. return $processor->processConfiguration($configuration, $configs);
  91. }
  92. /**
  93. * Registers factory resources for certain bundles.
  94. *
  95. * @param ContainerBuilder $container The container
  96. * @param array $bundles An array of select bundle names
  97. *
  98. * @throws InvalidArgumentException If registering resources from a bundle that doesn't exist
  99. */
  100. static protected function registerFormulaResources(ContainerBuilder $container, array $bundles)
  101. {
  102. $map = $container->getParameter('kernel.bundles');
  103. $am = $container->getDefinition('assetic.asset_manager');
  104. // bundle views/ directories and kernel overrides
  105. foreach ($bundles as $name) {
  106. $rc = new \ReflectionClass($map[$name]);
  107. foreach (array('twig', 'php') as $engine) {
  108. $container->setDefinition(
  109. 'assetic.'.$engine.'_directory_resource.'.$name,
  110. self::createDirectoryResourceDefinition($name, $engine, array(
  111. $container->getParameter('kernel.root_dir').'/Resources/'.$name.'/views',
  112. dirname($rc->getFileName()).'/Resources/views',
  113. ))
  114. );
  115. }
  116. }
  117. // kernel views/ directory
  118. foreach (array('twig', 'php') as $engine) {
  119. $container->setDefinition(
  120. 'assetic.'.$engine.'_directory_resource.kernel',
  121. self::createDirectoryResourceDefinition('', $engine, array(
  122. $container->getParameter('kernel.root_dir').'/Resources/views',
  123. ))
  124. );
  125. }
  126. }
  127. /**
  128. * Creates a directory resource definition.
  129. *
  130. * If more than one directory is provided a coalescing definition will be
  131. * returned.
  132. *
  133. * @param string $bundle A bundle name or empty string
  134. * @param string $engine The templating engine
  135. * @param array $dirs An array of directories to merge
  136. *
  137. * @return Definition A resource definition
  138. */
  139. static protected function createDirectoryResourceDefinition($bundle, $engine, array $dirs)
  140. {
  141. $dirResources = array();
  142. foreach ($dirs as $dir) {
  143. $dirResources[] = $dirResource = new Definition('%assetic.directory_resource.class%');
  144. $dirResource
  145. ->addArgument(new Reference('templating.loader'))
  146. ->addArgument($bundle)
  147. ->addArgument($dir)
  148. ->addArgument('/^[^.]+\.[^.]+\.'.$engine.'$/')
  149. ->setPublic(false);
  150. }
  151. if (1 == count($dirResources)) {
  152. // no need to coalesce
  153. $definition = $dirResources[0];
  154. } else {
  155. $definition = new Definition('%assetic.coalescing_directory_resource.class%');
  156. $definition
  157. ->addArgument($dirResources)
  158. ->setPublic(false);
  159. }
  160. return $definition
  161. ->addTag('assetic.templating.'.$engine)
  162. ->addTag('assetic.formula_resource', array('loader' => $engine));
  163. }
  164. /**
  165. * Returns the base path for the XSD files.
  166. *
  167. * @return string The XSD base path
  168. */
  169. public function getXsdValidationBasePath()
  170. {
  171. return __DIR__ . '/../Resources/config/schema';
  172. }
  173. public function getNamespace()
  174. {
  175. return 'http://symfony.com/schema/dic/assetic';
  176. }
  177. }