diff --git a/composer.json b/composer.json
index 86bdef044c3..f13ae88e271 100644
--- a/composer.json
+++ b/composer.json
@@ -37,7 +37,7 @@
"symfony/asset": "^4.4",
"symfony/config": "^4.4",
"symfony/console": "^4.4",
- "symfony/dependency-injection": "^4.4.3",
+ "symfony/dependency-injection": "^4.4.8",
"symfony/doctrine-bridge": "^4.4",
"symfony/event-dispatcher": "^4.4",
"symfony/event-dispatcher-contracts": "^1.1 || ^2.0",
diff --git a/src/DependencyInjection/SonataAdminExtension.php b/src/DependencyInjection/SonataAdminExtension.php
index 0bf372dce0a..9bb814f3368 100644
--- a/src/DependencyInjection/SonataAdminExtension.php
+++ b/src/DependencyInjection/SonataAdminExtension.php
@@ -18,7 +18,7 @@
use Symfony\Component\Config\FileLocator;
use Symfony\Component\DependencyInjection\ContainerBuilder;
use Symfony\Component\DependencyInjection\Extension\PrependExtensionInterface;
-use Symfony\Component\DependencyInjection\Loader\XmlFileLoader;
+use Symfony\Component\DependencyInjection\Loader\PhpFileLoader;
use Symfony\Component\DependencyInjection\Reference;
use Symfony\Component\Form\Extension\Core\Type\ChoiceType as SymfonyChoiceType;
use Symfony\Component\Form\Extension\Core\Type\DateTimeType as SymfonyDateTimeType;
@@ -59,24 +59,24 @@ public function load(array $configs, ContainerBuilder $container)
]);
}
- $loader = new XmlFileLoader($container, new FileLocator(__DIR__.'/../Resources/config'));
- $loader->load('actions.xml');
- $loader->load('block.xml');
- $loader->load('commands.xml');
- $loader->load('core.xml');
- $loader->load('event_listener.xml');
- $loader->load('form_types.xml');
- $loader->load('menu.xml');
- $loader->load('route.xml');
- $loader->load('twig.xml');
- $loader->load('validator.xml');
+ $loader = new PhpFileLoader($container, new FileLocator(__DIR__.'/../Resources/config'));
+ $loader->load('actions.php');
+ $loader->load('block.php');
+ $loader->load('commands.php');
+ $loader->load('core.php');
+ $loader->load('event_listener.php');
+ $loader->load('form_types.php');
+ $loader->load('menu.php');
+ $loader->load('route.php');
+ $loader->load('twig.php');
+ $loader->load('validator.php');
if (isset($bundles['MakerBundle'])) {
- $loader->load('makers.xml');
+ $loader->load('makers.php');
}
if (isset($bundles['SonataExporterBundle'])) {
- $loader->load('exporter.xml');
+ $loader->load('exporter.php');
}
$configuration = $this->getConfiguration($configs, $container);
@@ -157,7 +157,7 @@ public function load(array $configs, ContainerBuilder $container)
$container->setParameter('sonata.admin.configuration.security.admin_permissions', $config['security']['admin_permissions']);
$container->setParameter('sonata.admin.configuration.security.object_permissions', $config['security']['object_permissions']);
- $loader->load('security.xml');
+ $loader->load('security.php');
$container->setParameter('sonata.admin.extension.map', $config['extensions']);
@@ -272,10 +272,10 @@ private function replacePropertyAccessor(ContainerBuilder $container): void
/**
* NEXT_MAJOR: remove this method.
*/
- private function configureTwigTextExtension(ContainerBuilder $container, XmlFileLoader $loader, array $config): void
+ private function configureTwigTextExtension(ContainerBuilder $container, PhpFileLoader $loader, array $config): void
{
$container->setParameter('sonata.admin.configuration.legacy_twig_text_extension', $config['options']['legacy_twig_text_extension']);
- $loader->load('twig_string.xml');
+ $loader->load('twig_string.php');
if (false !== $config['options']['legacy_twig_text_extension']) {
$container
diff --git a/src/Export/Exporter.php b/src/Export/Exporter.php
index 39f5c23cd17..a475ce96825 100644
--- a/src/Export/Exporter.php
+++ b/src/Export/Exporter.php
@@ -36,6 +36,6 @@ public function __construct()
} else {
class_alias(
BaseExporter::class,
- __NAMESPACE__.'\Exporter'
+ 'Sonata\AdminBundle\Export\Exporter'
);
}
diff --git a/src/Resources/config/actions.php b/src/Resources/config/actions.php
new file mode 100644
index 00000000000..523274b6d28
--- /dev/null
+++ b/src/Resources/config/actions.php
@@ -0,0 +1,86 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Action\AppendFormFieldElementAction;
+use Sonata\AdminBundle\Action\DashboardAction;
+use Sonata\AdminBundle\Action\GetShortObjectDescriptionAction;
+use Sonata\AdminBundle\Action\RetrieveAutocompleteItemsAction;
+use Sonata\AdminBundle\Action\RetrieveFormFieldElementAction;
+use Sonata\AdminBundle\Action\SearchAction;
+use Sonata\AdminBundle\Action\SetObjectFieldValueAction;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set(DashboardAction::class, DashboardAction::class)
+ ->public()
+ ->args([
+ '%sonata.admin.configuration.dashboard_blocks%',
+ new ReferenceConfigurator('sonata.admin.breadcrumbs_builder'),
+ new ReferenceConfigurator('sonata.admin.global_template_registry'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('twig'),
+ ])
+
+ ->set(SearchAction::class, SearchAction::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.search.handler'),
+ new ReferenceConfigurator('sonata.admin.global_template_registry'),
+ new ReferenceConfigurator('sonata.admin.breadcrumbs_builder'),
+ new ReferenceConfigurator('twig'),
+ ])
+
+ ->set('sonata.admin.action.append_form_field_element', AppendFormFieldElementAction::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.helper'),
+ ])
+
+ ->set('sonata.admin.action.retrieve_form_field_element', RetrieveFormFieldElementAction::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.helper'),
+ ])
+
+ ->set('sonata.admin.action.get_short_object_description', GetShortObjectDescriptionAction::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ ])
+
+ ->set('sonata.admin.action.set_object_field_value', SetObjectFieldValueAction::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('validator'),
+ ])
+
+ ->set('sonata.admin.action.retrieve_autocomplete_items', RetrieveAutocompleteItemsAction::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/actions.xml b/src/Resources/config/actions.xml
deleted file mode 100644
index 1e3c0e49393..00000000000
--- a/src/Resources/config/actions.xml
+++ /dev/null
@@ -1,42 +0,0 @@
-
-
-
-
-
- %sonata.admin.configuration.dashboard_blocks%
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/block.php b/src/Resources/config/block.php
new file mode 100644
index 00000000000..7102ad86197
--- /dev/null
+++ b/src/Resources/config/block.php
@@ -0,0 +1,51 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Block\AdminListBlockService;
+use Sonata\AdminBundle\Block\AdminSearchBlockService;
+use Sonata\AdminBundle\Block\AdminStatsBlockService;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.block.admin_list', AdminListBlockService::class)
+ ->public()
+ ->tag('sonata.block')
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.global_template_registry'),
+ ])
+
+ ->set('sonata.admin.block.search_result', AdminSearchBlockService::class)
+ ->public()
+ ->tag('sonata.block')
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.search.handler'),
+ ])
+
+ ->set('sonata.admin.block.stats', AdminStatsBlockService::class)
+ ->public()
+ ->tag('sonata.block')
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/block.xml b/src/Resources/config/block.xml
deleted file mode 100644
index 8b91fca9c15..00000000000
--- a/src/Resources/config/block.xml
+++ /dev/null
@@ -1,22 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/commands.php b/src/Resources/config/commands.php
new file mode 100644
index 00000000000..6106f775afc
--- /dev/null
+++ b/src/Resources/config/commands.php
@@ -0,0 +1,71 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Command\CreateClassCacheCommand;
+use Sonata\AdminBundle\Command\ExplainAdminCommand;
+use Sonata\AdminBundle\Command\GenerateObjectAclCommand;
+use Sonata\AdminBundle\Command\ListAdminCommand;
+use Sonata\AdminBundle\Command\SetupAclCommand;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ // NEXT_MAJOR: Remove this service.
+ ->set(CreateClassCacheCommand::class, CreateClassCacheCommand::class)
+ ->public()
+ ->tag('console.command', [
+ 'command' => 'cache:create-cache-class',
+ ])
+ ->deprecate('The "%service_id%" service is deprecated since version sonata-project/admin-bundle 3.39.0 and will be removed in 4.0.')
+ ->args([
+ '%kernel.cache_dir%',
+ '%kernel.debug%',
+ ])
+
+ ->set(ExplainAdminCommand::class, ExplainAdminCommand::class)
+ ->public()
+ ->tag('console.command')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('validator'),
+ ])
+
+ ->set(GenerateObjectAclCommand::class, GenerateObjectAclCommand::class)
+ ->public()
+ ->tag('console.command')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ [],
+ (new ReferenceConfigurator('doctrine'))->nullOnInvalid(),
+ ])
+
+ ->set(ListAdminCommand::class, ListAdminCommand::class)
+ ->public()
+ ->tag('console.command')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ ])
+
+ ->set(SetupAclCommand::class, SetupAclCommand::class)
+ ->public()
+ ->tag('console.command')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.manipulator.acl.admin'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/commands.xml b/src/Resources/config/commands.xml
deleted file mode 100644
index cbc706cda63..00000000000
--- a/src/Resources/config/commands.xml
+++ /dev/null
@@ -1,31 +0,0 @@
-
-
-
-
-
- %kernel.cache_dir%
- %kernel.debug%
- The "%service_id%" service is deprecated since version sonata-project/admin-bundle 3.39.0 and will be removed in 4.0.
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/core.php b/src/Resources/config/core.php
new file mode 100644
index 00000000000..e590b9fff18
--- /dev/null
+++ b/src/Resources/config/core.php
@@ -0,0 +1,232 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Admin\AdminHelper;
+use Sonata\AdminBundle\Admin\BreadcrumbsBuilder;
+use Sonata\AdminBundle\Admin\BreadcrumbsBuilderInterface;
+use Sonata\AdminBundle\Admin\Extension\LockExtension;
+use Sonata\AdminBundle\Admin\Pool;
+use Sonata\AdminBundle\Controller\HelperController;
+use Sonata\AdminBundle\Event\AdminEventExtension;
+use Sonata\AdminBundle\Export\Exporter;
+use Sonata\AdminBundle\Filter\FilterFactory;
+use Sonata\AdminBundle\Filter\FilterFactoryInterface;
+use Sonata\AdminBundle\Filter\Persister\FilterPersisterInterface;
+use Sonata\AdminBundle\Filter\Persister\SessionFilterPersister;
+use Sonata\AdminBundle\Model\AuditManager;
+use Sonata\AdminBundle\Model\AuditManagerInterface;
+use Sonata\AdminBundle\Route\AdminPoolLoader;
+use Sonata\AdminBundle\Search\SearchHandler;
+use Sonata\AdminBundle\Templating\MutableTemplateRegistryInterface;
+use Sonata\AdminBundle\Templating\TemplateRegistry;
+use Sonata\AdminBundle\Translator\BCLabelTranslatorStrategy;
+use Sonata\AdminBundle\Translator\Extractor\AdminExtractor;
+use Sonata\AdminBundle\Translator\Extractor\JMSTranslatorBundle\AdminExtractor as DeprecatedAdminExtractor;
+use Sonata\AdminBundle\Translator\FormLabelTranslatorStrategy;
+use Sonata\AdminBundle\Translator\LabelTranslatorStrategyInterface;
+use Sonata\AdminBundle\Translator\NativeLabelTranslatorStrategy;
+use Sonata\AdminBundle\Translator\NoopLabelTranslatorStrategy;
+use Sonata\AdminBundle\Translator\UnderscoreLabelTranslatorStrategy;
+use Sonata\AdminBundle\Twig\GlobalVariables;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.pool', Pool::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('service_container'),
+ '',
+ '',
+ [],
+ new ReferenceConfigurator('property_accessor'),
+ ])
+ ->call('setTemplateRegistry', [
+ new ReferenceConfigurator('sonata.admin.global_template_registry'),
+ ])
+
+ ->alias(Pool::class, 'sonata.admin.pool')
+
+ ->set('sonata.admin.route_loader', AdminPoolLoader::class)
+ ->public()
+ ->tag('routing.loader')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ '',
+ new ReferenceConfigurator('service_container'),
+ ])
+
+ ->alias(AdminPoolLoader::class, 'sonata.admin.route_loader')
+
+ ->set('sonata.admin.helper', AdminHelper::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ ])
+
+ ->alias(AdminHelper::class, 'sonata.admin.helper')
+
+ ->set('sonata.admin.builder.filter.factory', FilterFactory::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('service_container'),
+ '',
+ ])
+
+ ->alias(FilterFactory::class, 'sonata.admin.builder.filter.factory')
+
+ ->alias(FilterFactoryInterface::class, 'sonata.admin.builder.filter.factory')
+
+ ->set('sonata.admin.breadcrumbs_builder', BreadcrumbsBuilder::class)
+ ->public()
+ ->args([
+ '%sonata.admin.configuration.breadcrumbs%',
+ ])
+
+ ->alias(BreadcrumbsBuilder::class, 'sonata.admin.breadcrumbs_builder')
+
+ ->alias(BreadcrumbsBuilderInterface::class, 'sonata.admin.breadcrumbs_builder')
+
+ // Services used to format the label, default is sonata.admin.label.strategy.noop
+
+ ->set('sonata.admin.label.strategy.bc', BCLabelTranslatorStrategy::class)
+ ->public()
+
+ ->alias(BCLabelTranslatorStrategy::class, 'sonata.admin.label.strategy.bc')
+
+ ->set('sonata.admin.label.strategy.native', NativeLabelTranslatorStrategy::class)
+ ->public()
+
+ ->alias(NativeLabelTranslatorStrategy::class, 'sonata.admin.label.strategy.native')
+
+ ->alias(LabelTranslatorStrategyInterface::class, 'sonata.admin.label.strategy.native')
+
+ ->set('sonata.admin.label.strategy.noop', NoopLabelTranslatorStrategy::class)
+ ->public()
+
+ ->alias(NoopLabelTranslatorStrategy::class, 'sonata.admin.label.strategy.noop')
+
+ ->set('sonata.admin.label.strategy.underscore', UnderscoreLabelTranslatorStrategy::class)
+ ->public()
+
+ ->alias(UnderscoreLabelTranslatorStrategy::class, 'sonata.admin.label.strategy.underscore')
+
+ ->set('sonata.admin.label.strategy.form_component', FormLabelTranslatorStrategy::class)
+ ->public()
+
+ ->alias(FormLabelTranslatorStrategy::class, 'sonata.admin.label.strategy.form_component')
+
+ // NEXT_MAJOR: Remove this service.
+ ->set('sonata.admin.translator.extractor.jms_translator_bundle', DeprecatedAdminExtractor::class)
+ ->public()
+ ->tag('jms_translation.extractor', [
+ 'alias' => 'sonata_admin',
+ ])
+ ->deprecate('The service "%service_id%" is deprecated in favor of the "Sonata\AdminBundle\Translator\Extractor\AdminExtractor" service since version 3.72 and will be removed in 4.0.')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ (new ReferenceConfigurator('logger'))->nullOnInvalid(),
+ ])
+ ->call('setBreadcrumbsBuilder', [
+ new ReferenceConfigurator('sonata.admin.breadcrumbs_builder'),
+ ])
+
+ ->set(AdminExtractor::class)
+ ->tag('translation.extractor', [
+ 'alias' => 'sonata_admin',
+ ])
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.breadcrumbs_builder'),
+ ])
+
+ // NEXT_MAJOR: Remove this service.
+ ->set('sonata.admin.controller.admin', HelperController::class)
+ ->public()
+ ->deprecate('The controller service "%service_id%" is deprecated in favor of several action services since version 3.38.0 and will be removed in 4.0.')
+ ->args([
+ new ReferenceConfigurator('twig'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('sonata.admin.helper'),
+ new ReferenceConfigurator('validator'),
+ ])
+
+ ->set('sonata.admin.audit.manager', AuditManager::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('service_container'),
+ ])
+
+ ->alias(AuditManager::class, 'sonata.admin.audit.manager')
+
+ ->alias(AuditManagerInterface::class, 'sonata.admin.audit.manager')
+
+ // NEXT_MAJOR: Remove this service.
+ ->set('sonata.admin.exporter', Exporter::class)
+ ->public()
+ ->deprecate('The service "%service_id%" is deprecated in favor of the "sonata.exporter.exporter" service since version 3.14 and will be removed in 4.0.')
+
+ ->set('sonata.admin.search.handler', SearchHandler::class)
+ ->public()
+ ->args([
+ '%sonata.admin.configuration.global_search.case_sensitive%',
+ ])
+
+ ->alias(SearchHandler::class, 'sonata.admin.search.handler')
+
+ ->set('sonata.admin.event.extension', AdminEventExtension::class)
+ ->public()
+ ->tag('sonata.admin.extension', ['global' => true])
+ ->args([
+ new ReferenceConfigurator('event_dispatcher'),
+ ])
+
+ ->alias(AdminEventExtension::class, 'sonata.admin.event.extension')
+
+ ->set('sonata.admin.lock.extension', LockExtension::class)
+ ->public()
+ ->tag('sonata.admin.extension', ['global' => true])
+
+ ->set('sonata.admin.twig.global', GlobalVariables::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ '%sonata.admin.configuration.mosaic_background%',
+ ])
+
+ ->alias(GlobalVariables::class, 'sonata.admin.twig.global')
+
+ ->set('sonata.admin.filter_persister.session', SessionFilterPersister::class)
+ ->args([
+ new ReferenceConfigurator('session'),
+ ])
+
+ ->alias(SessionFilterPersister::class, 'sonata.admin.filter_persister.session')
+
+ ->alias(FilterPersisterInterface::class, 'sonata.admin.filter_persister.session')
+
+ ->set('sonata.admin.global_template_registry', TemplateRegistry::class)
+ ->public()
+ ->args([
+ '%sonata.admin.configuration.templates%',
+ ])
+
+ ->alias(TemplateRegistry::class, 'sonata.admin.global_template_registry')
+
+ ->alias(MutableTemplateRegistryInterface::class, 'sonata.admin.global_template_registry')
+ ;
+};
diff --git a/src/Resources/config/core.xml b/src/Resources/config/core.xml
deleted file mode 100644
index c7f4141e81d..00000000000
--- a/src/Resources/config/core.xml
+++ /dev/null
@@ -1,116 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- %sonata.admin.configuration.breadcrumbs%
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- The controller service "%service_id%" is deprecated in favor of several action services since version 3.38.0 and will be removed in 4.0.
-
-
-
-
-
-
-
-
-
-
-
-
-
- The service "%service_id%" is deprecated in favor of the "sonata.exporter.exporter" service since version 3.14 and will be removed in 4.0.
-
-
- %sonata.admin.configuration.global_search.case_sensitive%
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- %sonata.admin.configuration.mosaic_background%
-
-
-
-
-
-
-
-
-
-
- %sonata.admin.configuration.templates%
-
-
-
-
-
diff --git a/src/Resources/config/event_listener.php b/src/Resources/config/event_listener.php
new file mode 100644
index 00000000000..12923de6081
--- /dev/null
+++ b/src/Resources/config/event_listener.php
@@ -0,0 +1,34 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\EventListener\AssetsInstallCommandListener;
+use Symfony\Component\Console\ConsoleEvents;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set(AssetsInstallCommandListener::class)
+ ->tag('kernel.event_listener', [
+ 'event' => ConsoleEvents::TERMINATE,
+ 'method' => 'copySonataCoreBundleAssets',
+ ])
+ ->args([
+ new ReferenceConfigurator('filesystem'),
+ '%kernel.project_dir%',
+ ])
+ ;
+};
diff --git a/src/Resources/config/event_listener.xml b/src/Resources/config/event_listener.xml
deleted file mode 100644
index 0499a3ae8c5..00000000000
--- a/src/Resources/config/event_listener.xml
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
- %kernel.project_dir%
-
-
-
-
diff --git a/src/Resources/config/exporter.php b/src/Resources/config/exporter.php
new file mode 100644
index 00000000000..763026a0009
--- /dev/null
+++ b/src/Resources/config/exporter.php
@@ -0,0 +1,29 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Bridge\Exporter\AdminExporter;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.admin_exporter', AdminExporter::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.exporter.exporter'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/exporter.xml b/src/Resources/config/exporter.xml
deleted file mode 100644
index b188ae04872..00000000000
--- a/src/Resources/config/exporter.xml
+++ /dev/null
@@ -1,8 +0,0 @@
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/form_types.php b/src/Resources/config/form_types.php
new file mode 100644
index 00000000000..586542c437e
--- /dev/null
+++ b/src/Resources/config/form_types.php
@@ -0,0 +1,148 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Form\Extension\ChoiceTypeExtension;
+use Sonata\AdminBundle\Form\Extension\Field\Type\FormTypeFieldExtension;
+use Sonata\AdminBundle\Form\Extension\Field\Type\MopaCompatibilityTypeFieldExtension;
+use Sonata\AdminBundle\Form\Type\AdminType;
+use Sonata\AdminBundle\Form\Type\ChoiceFieldMaskType;
+use Sonata\AdminBundle\Form\Type\CollectionType;
+use Sonata\AdminBundle\Form\Type\Filter\ChoiceType;
+use Sonata\AdminBundle\Form\Type\Filter\DateRangeType;
+use Sonata\AdminBundle\Form\Type\Filter\DateTimeRangeType;
+use Sonata\AdminBundle\Form\Type\Filter\DateTimeType;
+use Sonata\AdminBundle\Form\Type\Filter\DateType;
+use Sonata\AdminBundle\Form\Type\Filter\DefaultType;
+use Sonata\AdminBundle\Form\Type\Filter\NumberType;
+use Sonata\AdminBundle\Form\Type\ModelAutocompleteType;
+use Sonata\AdminBundle\Form\Type\ModelHiddenType;
+use Sonata\AdminBundle\Form\Type\ModelListType;
+use Sonata\AdminBundle\Form\Type\ModelReferenceType;
+use Sonata\AdminBundle\Form\Type\ModelType;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+use Symfony\Component\Form\Extension\Core\Type\ChoiceType as SymfonyChoiceType;
+use Symfony\Component\Form\Extension\Core\Type\FormType;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.form.type.admin', AdminType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_admin'])
+ ->args([
+ new ReferenceConfigurator('sonata.admin.helper'),
+ ])
+
+ ->set('sonata.admin.form.type.model_choice', ModelType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_model'])
+ ->args([
+ new ReferenceConfigurator('property_accessor'),
+ ])
+
+ ->set('sonata.admin.form.type.model_list', ModelListType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_model_list'])
+
+ ->set('sonata.admin.form.type.model_reference', ModelReferenceType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_model_reference'])
+
+ ->set('sonata.admin.form.type.model_hidden', ModelHiddenType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_model_hidden'])
+
+ ->set('sonata.admin.form.type.model_autocomplete', ModelAutocompleteType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_model_autocomplete'])
+
+ ->set('sonata.admin.form.type.collection', CollectionType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_native_collection'])
+
+ ->set('sonata.admin.doctrine_orm.form.type.choice_field_mask', ChoiceFieldMaskType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_choice_field_mask'])
+
+ ->set('sonata.admin.form.extension.field', FormTypeFieldExtension::class)
+ ->public()
+ ->tag('form.type_extension', [
+ 'alias' => 'form',
+ 'extended_type' => FormType::class,
+ ])
+ ->args(['', ''])
+
+ ->set('sonata.admin.form.extension.field.mopa', MopaCompatibilityTypeFieldExtension::class)
+ ->public()
+ ->tag('form.type_extension', [
+ 'alias' => 'form',
+ 'extended_type' => FormType::class,
+ ])
+
+ ->set('sonata.admin.form.extension.choice', ChoiceTypeExtension::class)
+ ->public()
+ ->tag('form.type_extension', [
+ 'alias' => 'choice',
+ 'extended_type' => SymfonyChoiceType::class,
+ ])
+
+ ->set('sonata.admin.form.filter.type.number', NumberType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_filter_number'])
+ ->args([
+ new ReferenceConfigurator('translator'),
+ ])
+
+ ->set('sonata.admin.form.filter.type.choice', ChoiceType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_filter_choice'])
+ ->args([
+ new ReferenceConfigurator('translator'),
+ ])
+
+ ->set('sonata.admin.form.filter.type.default', DefaultType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_filter_default'])
+
+ ->set('sonata.admin.form.filter.type.date', DateType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_filter_date'])
+ ->args([
+ new ReferenceConfigurator('translator'),
+ ])
+
+ ->set('sonata.admin.form.filter.type.daterange', DateRangeType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_filter_date_range'])
+ ->args([
+ new ReferenceConfigurator('translator'),
+ ])
+
+ ->set('sonata.admin.form.filter.type.datetime', DateTimeType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_filter_datetime'])
+ ->args([
+ new ReferenceConfigurator('translator'),
+ ])
+
+ ->set('sonata.admin.form.filter.type.datetime_range', DateTimeRangeType::class)
+ ->public()
+ ->tag('form.type', ['alias' => 'sonata_type_filter_datetime_range'])
+ ->args([
+ new ReferenceConfigurator('translator'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/form_types.xml b/src/Resources/config/form_types.xml
deleted file mode 100644
index fd0e97ee032..00000000000
--- a/src/Resources/config/form_types.xml
+++ /dev/null
@@ -1,72 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/makers.php b/src/Resources/config/makers.php
new file mode 100644
index 00000000000..6ee8247e96a
--- /dev/null
+++ b/src/Resources/config/makers.php
@@ -0,0 +1,29 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Maker\AdminMaker;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.maker', AdminMaker::class)
+ ->tag('maker.command')
+ ->args([
+ '%kernel.project_dir%',
+ [],
+ ])
+ ;
+};
diff --git a/src/Resources/config/makers.xml b/src/Resources/config/makers.xml
deleted file mode 100644
index 92c2695f0fd..00000000000
--- a/src/Resources/config/makers.xml
+++ /dev/null
@@ -1,11 +0,0 @@
-
-
-
-
-
- %kernel.project_dir%
-
-
-
-
-
diff --git a/src/Resources/config/menu.php b/src/Resources/config/menu.php
new file mode 100644
index 00000000000..ad7bdd488fe
--- /dev/null
+++ b/src/Resources/config/menu.php
@@ -0,0 +1,72 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Knp\Menu\MenuItem;
+use Sonata\AdminBundle\Menu\Matcher\Voter\ActiveVoter;
+use Sonata\AdminBundle\Menu\Matcher\Voter\AdminVoter;
+use Sonata\AdminBundle\Menu\Matcher\Voter\ChildrenVoter;
+use Sonata\AdminBundle\Menu\MenuBuilder;
+use Sonata\AdminBundle\Menu\Provider\GroupMenuProvider;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.menu_builder', MenuBuilder::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('knp_menu.factory'),
+ new ReferenceConfigurator('knp_menu.menu_provider'),
+ new ReferenceConfigurator('event_dispatcher'),
+ ])
+
+ ->set('sonata.admin.sidebar_menu', MenuItem::class)
+ ->public()
+ ->tag('knp_menu.menu', ['alias' => 'sonata_admin_sidebar'])
+ ->factory([
+ new ReferenceConfigurator('sonata.admin.menu_builder'),
+ 'createSidebarMenu',
+ ])
+
+ ->set('sonata.admin.menu.group_provider', GroupMenuProvider::class)
+ ->tag('knp_menu.provider')
+ ->args([
+ new ReferenceConfigurator('knp_menu.factory'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ new ReferenceConfigurator('security.authorization_checker'),
+ ])
+
+ ->set('sonata.admin.menu.matcher.voter.admin', AdminVoter::class)
+ ->public()
+ ->tag('knp_menu.voter')
+ ->args([
+ new ReferenceConfigurator('request_stack'),
+ ])
+
+ // NEXT_MAJOR: Remove this service.
+ ->set('sonata.admin.menu.matcher.voter.children', ChildrenVoter::class)
+ ->public()
+ ->deprecate('The "%service_id%" service is deprecated since 3.28 and will be removed in 4.0.')
+ ->args([
+ new ReferenceConfigurator('knp_menu.matcher'),
+ ])
+
+ ->set('sonata.admin.menu.matcher.voter.active', ActiveVoter::class)
+ ->public()
+ ->tag('knp_menu.voter')
+ ;
+};
diff --git a/src/Resources/config/menu.xml b/src/Resources/config/menu.xml
deleted file mode 100644
index 8f87d94c753..00000000000
--- a/src/Resources/config/menu.xml
+++ /dev/null
@@ -1,32 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/route.php b/src/Resources/config/route.php
new file mode 100644
index 00000000000..75e63e8528c
--- /dev/null
+++ b/src/Resources/config/route.php
@@ -0,0 +1,61 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Route\DefaultRouteGenerator;
+use Sonata\AdminBundle\Route\PathInfoBuilder;
+use Sonata\AdminBundle\Route\QueryStringBuilder;
+use Sonata\AdminBundle\Route\RoutesCache;
+use Sonata\AdminBundle\Route\RoutesCacheWarmUp;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.route.path_info', PathInfoBuilder::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.admin.audit.manager'),
+ ])
+
+ ->set('sonata.admin.route.query_string', QueryStringBuilder::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('sonata.admin.audit.manager'),
+ ])
+
+ ->set('sonata.admin.route.default_generator', DefaultRouteGenerator::class)
+ ->public()
+ ->args([
+ new ReferenceConfigurator('router'),
+ new ReferenceConfigurator('sonata.admin.route.cache'),
+ ])
+
+ ->set('sonata.admin.route.cache', RoutesCache::class)
+ ->public()
+ ->args([
+ '%kernel.cache_dir%/sonata/admin',
+ '%kernel.debug%',
+ ])
+
+ ->set('sonata.admin.route.cache_warmup', RoutesCacheWarmUp::class)
+ ->public()
+ ->tag('kernel.cache_warmer')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.route.cache'),
+ new ReferenceConfigurator('sonata.admin.pool'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/route.xml b/src/Resources/config/route.xml
deleted file mode 100644
index d055132950f..00000000000
--- a/src/Resources/config/route.xml
+++ /dev/null
@@ -1,24 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- %kernel.cache_dir%/sonata/admin
- %kernel.debug%
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/security.php b/src/Resources/config/security.php
new file mode 100644
index 00000000000..4c01045f089
--- /dev/null
+++ b/src/Resources/config/security.php
@@ -0,0 +1,79 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Security\Acl\Permission\MaskBuilder;
+use Sonata\AdminBundle\Security\Handler\AclSecurityHandler;
+use Sonata\AdminBundle\Security\Handler\NoopSecurityHandler;
+use Sonata\AdminBundle\Security\Handler\RoleSecurityHandler;
+use Sonata\AdminBundle\Util\AdminAclManipulator;
+use Sonata\AdminBundle\Util\AdminObjectAclManipulator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ $containerConfigurator->parameters()
+
+ ->set('sonata.admin.security.handler.noop.class', NoopSecurityHandler::class)
+
+ ->set('sonata.admin.security.handler.role.class', RoleSecurityHandler::class)
+
+ ->set('sonata.admin.security.handler.acl.class', AclSecurityHandler::class)
+
+ ->set('sonata.admin.security.mask.builder.class', MaskBuilder::class)
+
+ ->set('sonata.admin.manipulator.acl.admin.class', AdminAclManipulator::class)
+
+ ->set('sonata.admin.object.manipulator.acl.admin.class', AdminObjectAclManipulator::class)
+ ;
+
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.security.handler.noop', '%sonata.admin.security.handler.noop.class%')
+
+ ->set('sonata.admin.security.handler.role', '%sonata.admin.security.handler.role.class%')
+ ->args([
+ new ReferenceConfigurator('security.authorization_checker'),
+ [
+ '%sonata.admin.configuration.security.role_super_admin%',
+ ],
+ ])
+
+ ->set('sonata.admin.security.handler.acl', '%sonata.admin.security.handler.acl.class%')
+ ->args([
+ new ReferenceConfigurator('security.token_storage'),
+ new ReferenceConfigurator('security.authorization_checker'),
+ (new ReferenceConfigurator('security.acl.provider'))->nullOnInvalid(),
+ '%sonata.admin.security.mask.builder.class%',
+ [
+ '%sonata.admin.configuration.security.role_super_admin%',
+ ],
+ ])
+ ->call('setAdminPermissions', ['%sonata.admin.configuration.security.admin_permissions%'])
+ ->call('setObjectPermissions', ['%sonata.admin.configuration.security.object_permissions%'])
+
+ ->set('sonata.admin.manipulator.acl.admin', '%sonata.admin.manipulator.acl.admin.class%')
+ ->public()
+ ->args([
+ '%sonata.admin.security.mask.builder.class%',
+ ])
+
+ ->set('sonata.admin.object.manipulator.acl.admin', '%sonata.admin.object.manipulator.acl.admin.class%')
+ ->public()
+ ->args([
+ new ReferenceConfigurator('form.factory'),
+ '%sonata.admin.security.mask.builder.class%',
+ ])
+ ;
+};
diff --git a/src/Resources/config/security.xml b/src/Resources/config/security.xml
deleted file mode 100644
index 27547f26dd7..00000000000
--- a/src/Resources/config/security.xml
+++ /dev/null
@@ -1,42 +0,0 @@
-
-
-
- Sonata\AdminBundle\Security\Handler\NoopSecurityHandler
- Sonata\AdminBundle\Security\Handler\RoleSecurityHandler
- Sonata\AdminBundle\Security\Handler\AclSecurityHandler
- Sonata\AdminBundle\Security\Acl\Permission\MaskBuilder
- Sonata\AdminBundle\Util\AdminAclManipulator
- Sonata\AdminBundle\Util\AdminObjectAclManipulator
-
-
-
-
-
-
- %sonata.admin.configuration.security.role_super_admin%
-
-
-
-
-
-
- %sonata.admin.security.mask.builder.class%
-
- %sonata.admin.configuration.security.role_super_admin%
-
-
- %sonata.admin.configuration.security.admin_permissions%
-
-
- %sonata.admin.configuration.security.object_permissions%
-
-
-
- %sonata.admin.security.mask.builder.class%
-
-
-
- %sonata.admin.security.mask.builder.class%
-
-
-
diff --git a/src/Resources/config/twig.php b/src/Resources/config/twig.php
new file mode 100644
index 00000000000..b3b51f8d37b
--- /dev/null
+++ b/src/Resources/config/twig.php
@@ -0,0 +1,66 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Twig\Extension\SonataAdminExtension;
+use Sonata\AdminBundle\Twig\Extension\TemplateRegistryExtension;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ $containerConfigurator->parameters()
+
+ ->set('sonata.admin.twig.extension.x_editable_type_mapping', [
+ 'choice' => 'select',
+ 'boolean' => 'select',
+ 'text' => 'text',
+ 'textarea' => 'textarea',
+ 'html' => 'textarea',
+ 'email' => 'email',
+ 'string' => 'text',
+ 'smallint' => 'text',
+ 'bigint' => 'text',
+ 'integer' => 'number',
+ 'decimal' => 'number',
+ 'currency' => 'number',
+ 'percent' => 'number',
+ 'url' => 'url',
+ 'date' => 'date',
+ ])
+ ;
+
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.twig.extension', SonataAdminExtension::class)
+ ->public()
+ ->tag('twig.extension')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.pool'),
+ (new ReferenceConfigurator('logger'))->nullOnInvalid(),
+ new ReferenceConfigurator('translator'),
+ new ReferenceConfigurator('service_container'),
+ new ReferenceConfigurator('security.authorization_checker'),
+ ])
+ ->call('setXEditableTypeMapping', [
+ '%sonata.admin.twig.extension.x_editable_type_mapping%',
+ ])
+
+ ->set('sonata.templates.twig.extension', TemplateRegistryExtension::class)
+ ->tag('twig.extension')
+ ->args([
+ new ReferenceConfigurator('sonata.admin.global_template_registry'),
+ new ReferenceConfigurator('service_container'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/twig.xml b/src/Resources/config/twig.xml
deleted file mode 100644
index cd9431fa5b5..00000000000
--- a/src/Resources/config/twig.xml
+++ /dev/null
@@ -1,41 +0,0 @@
-
-
-
-
- select
- select
- text
- textarea
- textarea
- email
- text
- text
- text
- number
- number
- number
- number
- url
- date
-
-
-
-
-
-
-
-
-
-
-
-
- %sonata.admin.twig.extension.x_editable_type_mapping%
-
-
-
-
-
-
-
-
-
diff --git a/src/Resources/config/twig_string.php b/src/Resources/config/twig_string.php
new file mode 100644
index 00000000000..6da23e3e9ee
--- /dev/null
+++ b/src/Resources/config/twig_string.php
@@ -0,0 +1,31 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\AdminBundle\Twig\Extension\DeprecatedTextExtension;
+use Sonata\AdminBundle\Twig\Extension\StringExtension;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ $containerConfigurator->services()
+
+ ->set('sonata.string.twig.extension', StringExtension::class)
+ ->tag('twig.extension')
+ ->args([
+ null,
+ ])
+
+ ->set('sonata.deprecated_text.twig.extension', DeprecatedTextExtension::class)
+ ->tag('twig.extension')
+ ->deprecate('The "%service_id%" service is deprecated. You should stop using it, as it will be removed in the future.')
+ ;
+};
diff --git a/src/Resources/config/twig_string.xml b/src/Resources/config/twig_string.xml
deleted file mode 100644
index 3136aaa9368..00000000000
--- a/src/Resources/config/twig_string.xml
+++ /dev/null
@@ -1,13 +0,0 @@
-
-
-
-
-
- null
-
-
-
-
-
-
-
diff --git a/src/Resources/config/validator.php b/src/Resources/config/validator.php
new file mode 100644
index 00000000000..07b894db89e
--- /dev/null
+++ b/src/Resources/config/validator.php
@@ -0,0 +1,31 @@
+
+ *
+ * For the full copyright and license information, please view the LICENSE
+ * file that was distributed with this source code.
+ */
+
+use Sonata\Form\Validator\InlineValidator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ContainerConfigurator;
+use Symfony\Component\DependencyInjection\Loader\Configurator\ReferenceConfigurator;
+
+return static function (ContainerConfigurator $containerConfigurator): void {
+ // Use "service" function for creating references to services when dropping support for Symfony 4.4
+ // Use "param" function for creating references to parameters when dropping support for Symfony 5.1
+ $containerConfigurator->services()
+
+ ->set('sonata.admin.validator.inline', InlineValidator::class)
+ ->public()
+ ->tag('validator.constraint_validator', ['alias' => 'sonata.admin.validator.inline'])
+ ->args([
+ new ReferenceConfigurator('service_container'),
+ new ReferenceConfigurator('validator.validator_factory'),
+ ])
+ ;
+};
diff --git a/src/Resources/config/validator.xml b/src/Resources/config/validator.xml
deleted file mode 100644
index 67363571f6c..00000000000
--- a/src/Resources/config/validator.xml
+++ /dev/null
@@ -1,10 +0,0 @@
-
-
-
-
-
-
-
-
-
-