* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Bridge\Doctrine\DependencyInjection\CompilerPass; use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface; use Symfony\Component\DependencyInjection\ContainerBuilder; /** * Registers additional validators. * * @author Benjamin Eberlei */ class DoctrineValidationPass implements CompilerPassInterface { private string $managerType; public function __construct(string $managerType) { $this->managerType = $managerType; } /** * {@inheritdoc} */ public function process(ContainerBuilder $container) { $this->updateValidatorMappingFiles($container, 'xml', 'xml'); $this->updateValidatorMappingFiles($container, 'yaml', 'yml'); } /** * Gets the validation mapping files for the format and extends them with * files matching a doctrine search pattern (Resources/config/validation.orm.xml). */ private function updateValidatorMappingFiles(ContainerBuilder $container, string $mapping, string $extension) { if (!$container->hasParameter('validator.mapping.loader.'.$mapping.'_files_loader.mapping_files')) { return; } $files = $container->getParameter('validator.mapping.loader.'.$mapping.'_files_loader.mapping_files'); $validationPath = '/config/validation.'.$this->managerType.'.'.$extension; foreach ($container->getParameter('kernel.bundles_metadata') as $bundle) { if ($container->fileExists($file = $bundle['path'].'/Resources'.$validationPath) || $container->fileExists($file = $bundle['path'].$validationPath)) { $files[] = $file; } } $container->setParameter('validator.mapping.loader.'.$mapping.'_files_loader.mapping_files', $files); } }