SonataAdminExtension.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  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\AdminBundle\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\HttpKernel\DependencyInjection\Extension;
  16. use Symfony\Component\Config\FileLocator;
  17. use Symfony\Component\Config\Resource\FileResource;
  18. use Symfony\Component\Config\Definition\Processor;
  19. use Symfony\Component\Finder\Finder;
  20. /**
  21. * SonataAdminBundleExtension
  22. *
  23. * @author Thomas Rabaix <thomas.rabaix@sonata-project.org>
  24. * @author Michael Williams <michael.williams@funsational.com>
  25. */
  26. class SonataAdminExtension extends Extension
  27. {
  28. protected $configNamespaces = array(
  29. 'templates' => array(
  30. 'layout',
  31. 'ajax'
  32. )
  33. );
  34. /**
  35. *
  36. * @param array $config An array of configuration settings
  37. * @param ContainerBuilder $container A ContainerBuilder instance
  38. */
  39. public function load(array $configs, ContainerBuilder $container)
  40. {
  41. $loader = new XmlFileLoader($container, new FileLocator(__DIR__.'/../Resources/config'));
  42. $loader->load('templates.xml');
  43. $loader->load('field_types.xml');
  44. $configuration = new Configuration();
  45. $processor = new Processor();
  46. $config = $processor->process($configuration->getConfigTree($container->getParameter('kernel.debug')), $configs);
  47. // setups parameters with values in config.yml, default values from external files used if not
  48. $this->configSetupTemplates($config, $container);
  49. // register the twig extension
  50. $container
  51. ->register('twig.extension.sonata_admin', 'Sonata\AdminBundle\Twig\Extension\SonataAdminExtension')
  52. ->addTag('twig.extension');
  53. // register form builder
  54. $definition = new Definition('Sonata\AdminBundle\Builder\ORM\FormContractor', array(new Reference('form.factory'), new Reference('validator')));
  55. $container->setDefinition('sonata_admin.builder.orm_form', $definition);
  56. // register list builder
  57. $definition = new Definition('Sonata\AdminBundle\Builder\ORM\ListBuilder');
  58. $container->setDefinition('sonata_admin.builder.orm_list', $definition);
  59. // register filter builder
  60. $definition = new Definition('Sonata\AdminBundle\Builder\ORM\DatagridBuilder');
  61. $definition->addArgument(new Reference('form.factory'));
  62. $container->setDefinition('sonata_admin.builder.orm_datagrid', $definition);
  63. // registers crud action
  64. $definition = new Definition('Sonata\AdminBundle\Admin\Pool');
  65. $definition->addMethodCall('setContainer', array(new Reference('service_container')));
  66. $container->setDefinition('sonata_admin.admin.pool', $definition);
  67. $definition = new Definition('Sonata\AdminBundle\Route\AdminPoolLoader', array(
  68. new Reference('sonata_admin.admin.pool'),
  69. ));
  70. $definition->addTag('routing.loader');
  71. $container->setDefinition('sonata_admin.route_loader', $definition);
  72. }
  73. protected function configSetupTemplates($config, $container)
  74. {
  75. foreach ($this->configNamespaces as $ns => $params) {
  76. if (!isset($config[$ns])) {
  77. continue;
  78. }
  79. foreach ($config[$ns] as $type => $template) {
  80. if (!isset($config[$ns][$type])) {
  81. continue;
  82. }
  83. $container->setParameter(sprintf('sonata_admin.templates.%s', $type), $template);
  84. }
  85. }
  86. }
  87. /**
  88. * Returns the base path for the XSD files.
  89. *
  90. * @return string The XSD base path
  91. */
  92. public function getXsdValidationBasePath()
  93. {
  94. return __DIR__.'/../Resources/config/schema';
  95. }
  96. public function getNamespace()
  97. {
  98. return 'http://www.sonata-project.org/schema/dic/admin';
  99. }
  100. public function getAlias()
  101. {
  102. return "sonata_admin";
  103. }
  104. }