From 6b2225a8773c3ae2a74cb9782599c8e8eb93c031 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Michael=20K=C3=BChn?= Date: Sat, 17 Feb 2018 15:46:45 +0100 Subject: [PATCH] #7068 early exit if arguments are not sane for given lockMode --- lib/Doctrine/ORM/EntityManager.php | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) diff --git a/lib/Doctrine/ORM/EntityManager.php b/lib/Doctrine/ORM/EntityManager.php index 602adca20b4..72dc8b92e31 100644 --- a/lib/Doctrine/ORM/EntityManager.php +++ b/lib/Doctrine/ORM/EntityManager.php @@ -385,6 +385,18 @@ public function find($entityName, $id, $lockMode = null, $lockVersion = null) $class = $this->metadataFactory->getMetadataFor(ltrim($entityName, '\\')); $className = $class->getClassName(); + switch ($lockMode) { + case LockMode::OPTIMISTIC: + if ( ! $class->isVersioned()) { + throw OptimisticLockException::notVersioned($className); + } + case LockMode::PESSIMISTIC_READ: + case LockMode::PESSIMISTIC_WRITE: + if (! $this->getConnection()->isTransactionActive()) { + throw TransactionRequiredException::transactionRequired(); + } + } + if (! is_array($id)) { if ($class->isIdentifierComposite()) { throw ORMInvalidArgumentException::invalidCompositeIdentifier(); @@ -446,25 +458,15 @@ public function find($entityName, $id, $lockMode = null, $lockVersion = null) $persister = $unitOfWork->getEntityPersister($className); switch (true) { - case $lockMode === LockMode::OPTIMISTIC: - if (! $class->isVersioned()) { - throw OptimisticLockException::notVersioned($className); - } - + case$lockMode === LockMode::OPTIMISTIC: $entity = $persister->load($sortedId); $unitOfWork->lock($entity, $lockMode, $lockVersion); return $entity; - case $lockMode === LockMode::PESSIMISTIC_READ: case $lockMode === LockMode::PESSIMISTIC_WRITE: - if (! $this->getConnection()->isTransactionActive()) { - throw TransactionRequiredException::transactionRequired(); - } - return $persister->load($sortedId, null, null, [], $lockMode); - default: return $persister->loadById($sortedId); }