From dc8219765a7883b9db249a9ffa9087c97fed8f3e Mon Sep 17 00:00:00 2001 From: David Buchmann Date: Fri, 2 Aug 2024 14:25:38 +0200 Subject: [PATCH] Fix BC break in PHPCR-ODM: we must no longer call the removed addDocumentNamespace method --- CHANGELOG.md | 7 +++++ .../Compiler/DoctrinePhpcrMappingsPass.php | 26 +++++-------------- 2 files changed, 14 insertions(+), 19 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f2189c3..1e692b9 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,13 @@ Changelog Version 3 ========= +3.0.2 +----- + +* Fixed `DoctrinePhpcrMappingPass` to not configure the `addDocumentNamespace` method which has been removed in PHPCR-ODM 2.0. +* [BC Break] Removed the `$aliasMap` parameter from `DoctrinePhpcrMappingPass` because this functionality has been removed in PHPCR-ODM 2.0 + (This is considered a 3.0 BC break - the mapping pass was broken in 3.0.0 and 3.0.1 because it tried to call `addDocumentNamespace`) + 3.0.1 ----- diff --git a/src/DependencyInjection/Compiler/DoctrinePhpcrMappingsPass.php b/src/DependencyInjection/Compiler/DoctrinePhpcrMappingsPass.php index b2310b8..81c16f0 100644 --- a/src/DependencyInjection/Compiler/DoctrinePhpcrMappingsPass.php +++ b/src/DependencyInjection/Compiler/DoctrinePhpcrMappingsPass.php @@ -32,9 +32,8 @@ final class DoctrinePhpcrMappingsPass extends RegisterMappingsPass * @param string|bool $enabledParameter Service container parameter that must be * present to enable the mapping. Set to false * to not do any check, optional. - * @param array $aliasMap map of alias to namespace */ - public function __construct($driver, array $namespaces, array $managerParameters, $enabledParameter = false, array $aliasMap = []) + public function __construct($driver, array $namespaces, array $managerParameters, $enabledParameter = false) { $managerParameters[] = 'doctrine_phpcr.odm.default_document_manager'; parent::__construct( @@ -44,8 +43,6 @@ public function __construct($driver, array $namespaces, array $managerParameters 'doctrine_phpcr.odm.%s_metadata_driver', $enabledParameter, 'doctrine_phpcr.odm.%s_configuration', - 'addDocumentNamespace', - $aliasMap ); } @@ -58,19 +55,17 @@ public function __construct($driver, array $namespaces, array $managerParameters * @param string|bool $enabledParameter Service container parameter that must be present to * enable the mapping. Set to false to not do any check, * optional. - * @param string[] $aliasMap map of alias to namespace */ public static function createXmlMappingDriver( array $namespaces, array $managerParameters = [], $enabledParameter = false, - array $aliasMap = [] ): self { $arguments = [$namespaces, '.phpcr.xml']; $locator = new Definition(SymfonyFileLocator::class, $arguments); $driver = new Definition(XmlDriver::class, [$locator]); - return new self($driver, $namespaces, $managerParameters, $enabledParameter, $aliasMap); + return new self($driver, $namespaces, $managerParameters, $enabledParameter); } /** @@ -82,19 +77,17 @@ public static function createXmlMappingDriver( * @param string|bool $enabledParameter Service container parameter that must be present to * enable the mapping. Set to false to not do any check, * optional. - * @param string[] $aliasMap map of alias to namespace */ public static function createYamlMappingDriver( array $namespaces, array $managerParameters = [], $enabledParameter = false, - array $aliasMap = [] ): self { $arguments = [$namespaces, '.phpcr.yml']; $locator = new Definition(SymfonyFileLocator::class, $arguments); $driver = new Definition(YamlDriver::class, [$locator]); - return new self($driver, $namespaces, $managerParameters, $enabledParameter, $aliasMap); + return new self($driver, $namespaces, $managerParameters, $enabledParameter); } /** @@ -106,19 +99,17 @@ public static function createYamlMappingDriver( * @param string|bool $enabledParameter Service container parameter that must be present to * enable the mapping. Set to false to not do any check, * optional. - * @param string[] $aliasMap map of alias to namespace */ public static function createPhpMappingDriver( array $mappings, array $managerParameters = [], $enabledParameter = false, - array $aliasMap = [] ): self { $arguments = [$mappings, '.php']; $locator = new Definition(SymfonyFileLocator::class, $arguments); $driver = new Definition(PHPDriver::class, [$locator]); - return new self($driver, $mappings, $managerParameters, $enabledParameter, $aliasMap); + return new self($driver, $mappings, $managerParameters, $enabledParameter); } /** @@ -131,16 +122,15 @@ public static function createPhpMappingDriver( * @param string|false $enabledParameter Service container parameter that must be present to * enable the mapping. Set to false to not do any check, * optional. - * @param string[] $aliasMap map of alias to namespace * @param bool $reportFieldsWhereDeclared Will report fields for the classes where they are declared * * @return self */ - public static function createAttributeMappingDriver(array $namespaces, array $directories, array $managerParameters = [], $enabledParameter = false, array $aliasMap = [], bool $reportFieldsWhereDeclared = false) + public static function createAttributeMappingDriver(array $namespaces, array $directories, array $managerParameters = [], $enabledParameter = false, bool $reportFieldsWhereDeclared = false) { $driver = new Definition(AttributeDriver::class, [$directories, $reportFieldsWhereDeclared]); - return new self($driver, $namespaces, $managerParameters, $enabledParameter, $aliasMap); + return new self($driver, $namespaces, $managerParameters, $enabledParameter); } /** @@ -153,17 +143,15 @@ public static function createAttributeMappingDriver(array $namespaces, array $di * @param string|bool $enabledParameter Service container parameter that must be present to * enable the mapping. Set to false to not do any check, * optional. - * @param string[] $aliasMap map of alias to namespace */ public static function createStaticPhpMappingDriver( array $namespaces, array $directories, array $managerParameters = [], $enabledParameter = false, - array $aliasMap = [] ): self { $driver = new Definition(StaticPHPDriver::class, [$directories]); - return new self($driver, $namespaces, $managerParameters, $enabledParameter, $aliasMap); + return new self($driver, $namespaces, $managerParameters, $enabledParameter); } }