entity = $entity; } /** * Gets the entity that caused the exception. * * @return object|string|null */ public function getEntity() { return $this->entity; } /** * @param object|class-string $entity * * @return OptimisticLockException */ public static function lockFailed($entity) { return new self('The optimistic lock on an entity failed.', $entity); } /** * @param object $entity * @param int|string|DateTimeInterface $expectedLockVersion * @param int|string|DateTimeInterface $actualLockVersion * * @return OptimisticLockException */ public static function lockFailedVersionMismatch($entity, $expectedLockVersion, $actualLockVersion) { $expectedLockVersion = $expectedLockVersion instanceof DateTimeInterface ? $expectedLockVersion->getTimestamp() : $expectedLockVersion; $actualLockVersion = $actualLockVersion instanceof DateTimeInterface ? $actualLockVersion->getTimestamp() : $actualLockVersion; return new self('The optimistic lock failed, version ' . $expectedLockVersion . ' was expected, but is actually ' . $actualLockVersion, $entity); } /** * @param string $entityName * * @return OptimisticLockException */ public static function notVersioned($entityName) { return new self('Cannot obtain optimistic lock on unversioned entity ' . $entityName, null); } }