SonataBaseApplicationExtension.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <?php
  2. /*
  3. * This file is part of the Sonata project.
  4. *
  5. * (c) Thomas Rabaix <thomas.rabaix@sonata-project.org>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Sonata\BaseApplicationBundle\DependencyInjection;
  11. use Symfony\Component\DependencyInjection\Loader\XmlFileLoader;
  12. use Symfony\Component\DependencyInjection\ContainerBuilder;
  13. use Symfony\Component\DependencyInjection\Reference;
  14. use Symfony\Component\DependencyInjection\Definition;
  15. use Symfony\Component\DependencyInjection\Extension\Extension;
  16. use Symfony\Component\Config\FileLocator;
  17. use Symfony\Component\Config\Resource\FileResource;
  18. use Symfony\Component\Finder\Finder;
  19. /**
  20. * SonataBaseApplicationExtension
  21. *
  22. *
  23. * @author Thomas Rabaix <thomas.rabaix@sonata-project.org>
  24. */
  25. class SonataBaseApplicationExtension extends Extension
  26. {
  27. protected $configNamespaces = array(
  28. 'templates' => array(
  29. 'layout',
  30. 'ajax'
  31. )
  32. );
  33. /**
  34. * Loads the url shortener configuration.
  35. *
  36. * @param array $config An array of configuration settings
  37. * @param ContainerBuilder $container A ContainerBuilder instance
  38. */
  39. public function load(array $config, ContainerBuilder $container)
  40. {
  41. $config = call_user_func_array('array_merge_recursive', $config);
  42. // loads config from external files
  43. $this->configLoadFiles($container);
  44. // setups parameters with values in config.yml, default values from external files used if not
  45. $this->configSetup($config, $container);
  46. // register the twig extension
  47. $container
  48. ->register('twig.extension.sonata_base_application', 'Sonata\BaseApplicationBundle\Twig\Extension\SonataBaseApplicationExtension')
  49. ->addTag('twig.extension');
  50. // register form builder
  51. $definition = new Definition('Sonata\BaseApplicationBundle\Builder\FormBuilder', array(new Reference('form.field_factory'), new Reference('form.context'), new Reference('validator')));
  52. $container->setDefinition('sonata_base_application.builder.orm_form', $definition);
  53. // register list builder
  54. $definition = new Definition('Sonata\BaseApplicationBundle\Builder\ListBuilder');
  55. $container->setDefinition('sonata_base_application.builder.orm_list', $definition);
  56. // register filter builder
  57. $definition = new Definition('Sonata\BaseApplicationBundle\Builder\DatagridBuilder');
  58. $container->setDefinition('sonata_base_application.builder.orm_datagrid', $definition);
  59. // registers crud action
  60. $definition = new Definition('Sonata\BaseApplicationBundle\Admin\Pool');
  61. $definition->addMethodCall('setContainer', array(new Reference('service_container')));
  62. foreach ($config['entities'] as $code => $configuration) {
  63. if (!isset($configuration['group'])) {
  64. $configuration['group'] = 'default';
  65. }
  66. if (!isset($configuration['label'])) {
  67. $configuration['label'] = $code;
  68. }
  69. if (!isset($configuration['children'])) {
  70. $configuration['children'] = array();
  71. }
  72. if (!isset($configuration['options'])) {
  73. $configuration['options'] = array();
  74. }
  75. if (!isset($configuration['options']['show_in_dashboard'])) {
  76. $configuration['options']['show_in_dashboard'] = true;
  77. }
  78. $definition->addMethodCall('addConfiguration', array($code, $configuration));
  79. }
  80. $container->setDefinition('sonata_base_application.admin.pool', $definition);
  81. $definition = new Definition('Sonata\BaseApplicationBundle\Route\AdminPoolLoader', array(new Reference('sonata_base_application.admin.pool')));
  82. $definition->addTag('routing.loader');
  83. $container->setDefinition('sonata_base_application.route_loader', $definition);
  84. }
  85. protected function configLoadFiles($container)
  86. {
  87. $loader = new XmlFileLoader($container, new FileLocator(__DIR__.'/../Resources/config'));
  88. foreach ($this->configNamespaces as $ns => $params) {
  89. $loader->load(sprintf('%s.xml', $ns));
  90. }
  91. }
  92. protected function configSetup($configs, $container)
  93. {
  94. foreach ($configs as $config) {
  95. foreach ($this->configNamespaces as $ns => $params) {
  96. if (!isset($config[$ns])) {
  97. continue;
  98. }
  99. foreach ($config[$ns] as $type => $template) {
  100. if (!isset($config[$ns][$type])) {
  101. continue;
  102. }
  103. $container->setParameter(sprintf('sonata_base_application.templates.%s', $type), $template);
  104. }
  105. }
  106. }
  107. }
  108. /**
  109. * Returns the base path for the XSD files.
  110. *
  111. * @return string The XSD base path
  112. */
  113. public function getXsdValidationBasePath()
  114. {
  115. return __DIR__.'/../Resources/config/schema';
  116. }
  117. public function getNamespace()
  118. {
  119. return 'http://www.sonata-project.org/schema/dic/base-application';
  120. }
  121. public function getAlias()
  122. {
  123. return "sonata_base_application";
  124. }
  125. }