SonataAdminExtension.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  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. /**
  20. * SonataAdminBundleExtension
  21. *
  22. * @author Thomas Rabaix <thomas.rabaix@sonata-project.org>
  23. * @author Michael Williams <michael.williams@funsational.com>
  24. */
  25. class SonataAdminExtension extends Extension
  26. {
  27. protected $configNamespaces = array(
  28. 'templates' => array(
  29. 'layout',
  30. 'ajax'
  31. )
  32. );
  33. protected $requestMatchers = array();
  34. /**
  35. *
  36. * @param array $configs An array of configuration settings
  37. * @param ContainerBuilder $container A ContainerBuilder instance
  38. */
  39. public function load(array $config, ContainerBuilder $container)
  40. {
  41. $loader = new XmlFileLoader($container, new FileLocator(__DIR__.'/../Resources/config'));
  42. $loader->load('templates.xml');
  43. $loader->load('doctrine_orm.xml');
  44. $loader->load('doctrine_orm_filter_types.xml');
  45. $loader->load('twig.xml');
  46. $loader->load('core.xml');
  47. $loader->load('form_types.xml');
  48. $loader->load('validator.xml');
  49. $configuration = new Configuration();
  50. $processor = new Processor();
  51. $config = $processor->processConfiguration($configuration, $config);
  52. // setups parameters with values in config.yml, default values from external files used if not
  53. $this->configSetupTemplates($config, $container);
  54. $pool = $container->getDefinition('sonata.admin.pool');
  55. $pool->addMethodCall('__hack__', $config);
  56. $container->setAlias('sonata.admin.security.handler', $config['security_handler']);
  57. }
  58. /**
  59. * setup the templates config
  60. *
  61. * @param array $config An array of configuration settings
  62. * @param ContainerBuilder $container A ContainerBuilder instance
  63. * @return void
  64. */
  65. protected function configSetupTemplates(array $config, ContainerBuilder $container)
  66. {
  67. foreach ($this->configNamespaces as $ns => $params) {
  68. if (!isset($config[$ns])) {
  69. continue;
  70. }
  71. foreach ($config[$ns] as $type => $template) {
  72. if (!isset($config[$ns][$type])) {
  73. continue;
  74. }
  75. $container->setParameter(sprintf('sonata.admin.templates.%s', $type), $template);
  76. }
  77. }
  78. }
  79. /**
  80. * Returns the base path for the XSD files.
  81. *
  82. * @return string The XSD base path
  83. */
  84. public function getXsdValidationBasePath()
  85. {
  86. return __DIR__.'/../Resources/config/schema';
  87. }
  88. public function getNamespace()
  89. {
  90. return 'http://www.sonata-project.org/schema/dic/admin';
  91. }
  92. public function getAlias()
  93. {
  94. return "sonata_admin";
  95. }
  96. }