From bf6655a534a6775d30cafa67bd801276bda1d98d Mon Sep 17 00:00:00 2001 From: polo Date: Tue, 13 Aug 2024 23:45:21 +0200 Subject: =?UTF-8?q?VERSION=200.2=20doctrine=20ORM=20et=20entit=C3=A9s?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/Persistence/Event/LifecycleEventArgs.php | 54 ++++++++++ .../Event/LoadClassMetadataEventArgs.php | 61 ++++++++++++ .../src/Persistence/Event/ManagerEventArgs.php | 39 ++++++++ .../src/Persistence/Event/OnClearEventArgs.php | 42 ++++++++ .../src/Persistence/Event/PreUpdateEventArgs.php | 110 +++++++++++++++++++++ 5 files changed, 306 insertions(+) create mode 100644 vendor/doctrine/persistence/src/Persistence/Event/LifecycleEventArgs.php create mode 100644 vendor/doctrine/persistence/src/Persistence/Event/LoadClassMetadataEventArgs.php create mode 100644 vendor/doctrine/persistence/src/Persistence/Event/ManagerEventArgs.php create mode 100644 vendor/doctrine/persistence/src/Persistence/Event/OnClearEventArgs.php create mode 100644 vendor/doctrine/persistence/src/Persistence/Event/PreUpdateEventArgs.php (limited to 'vendor/doctrine/persistence/src/Persistence/Event') diff --git a/vendor/doctrine/persistence/src/Persistence/Event/LifecycleEventArgs.php b/vendor/doctrine/persistence/src/Persistence/Event/LifecycleEventArgs.php new file mode 100644 index 0000000..1654de4 --- /dev/null +++ b/vendor/doctrine/persistence/src/Persistence/Event/LifecycleEventArgs.php @@ -0,0 +1,54 @@ +object = $object; + $this->objectManager = $objectManager; + } + + /** + * Retrieves the associated object. + * + * @return object + */ + public function getObject() + { + return $this->object; + } + + /** + * Retrieves the associated ObjectManager. + * + * @return ObjectManager + * @psalm-return TObjectManager + */ + public function getObjectManager() + { + return $this->objectManager; + } +} diff --git a/vendor/doctrine/persistence/src/Persistence/Event/LoadClassMetadataEventArgs.php b/vendor/doctrine/persistence/src/Persistence/Event/LoadClassMetadataEventArgs.php new file mode 100644 index 0000000..aa92d5d --- /dev/null +++ b/vendor/doctrine/persistence/src/Persistence/Event/LoadClassMetadataEventArgs.php @@ -0,0 +1,61 @@ + + * @template-covariant TObjectManager of ObjectManager + */ +class LoadClassMetadataEventArgs extends EventArgs +{ + /** + * @var ClassMetadata + * @psalm-var TClassMetadata + */ + private $classMetadata; + + /** + * @var ObjectManager + * @psalm-var TObjectManager + */ + private $objectManager; + + /** + * @psalm-param TClassMetadata $classMetadata + * @psalm-param TObjectManager $objectManager + */ + public function __construct(ClassMetadata $classMetadata, ObjectManager $objectManager) + { + $this->classMetadata = $classMetadata; + $this->objectManager = $objectManager; + } + + /** + * Retrieves the associated ClassMetadata. + * + * @return ClassMetadata + * @psalm-return TClassMetadata + */ + public function getClassMetadata() + { + return $this->classMetadata; + } + + /** + * Retrieves the associated ObjectManager. + * + * @return TObjectManager + */ + public function getObjectManager() + { + return $this->objectManager; + } +} diff --git a/vendor/doctrine/persistence/src/Persistence/Event/ManagerEventArgs.php b/vendor/doctrine/persistence/src/Persistence/Event/ManagerEventArgs.php new file mode 100644 index 0000000..5156013 --- /dev/null +++ b/vendor/doctrine/persistence/src/Persistence/Event/ManagerEventArgs.php @@ -0,0 +1,39 @@ +objectManager = $objectManager; + } + + /** + * Retrieves the associated ObjectManager. + * + * @return ObjectManager + * @psalm-return TObjectManager + */ + public function getObjectManager() + { + return $this->objectManager; + } +} diff --git a/vendor/doctrine/persistence/src/Persistence/Event/OnClearEventArgs.php b/vendor/doctrine/persistence/src/Persistence/Event/OnClearEventArgs.php new file mode 100644 index 0000000..519a887 --- /dev/null +++ b/vendor/doctrine/persistence/src/Persistence/Event/OnClearEventArgs.php @@ -0,0 +1,42 @@ +objectManager = $objectManager; + } + + /** + * Retrieves the associated ObjectManager. + * + * @return ObjectManager + * @psalm-return TObjectManager + */ + public function getObjectManager() + { + return $this->objectManager; + } +} diff --git a/vendor/doctrine/persistence/src/Persistence/Event/PreUpdateEventArgs.php b/vendor/doctrine/persistence/src/Persistence/Event/PreUpdateEventArgs.php new file mode 100644 index 0000000..95ecbd4 --- /dev/null +++ b/vendor/doctrine/persistence/src/Persistence/Event/PreUpdateEventArgs.php @@ -0,0 +1,110 @@ + + */ +class PreUpdateEventArgs extends LifecycleEventArgs +{ + /** @var array> */ + private $entityChangeSet; + + /** + * @param array> $changeSet + * @psalm-param TObjectManager $objectManager + */ + public function __construct(object $entity, ObjectManager $objectManager, array &$changeSet) + { + parent::__construct($entity, $objectManager); + + $this->entityChangeSet = &$changeSet; + } + + /** + * Retrieves the entity changeset. + * + * @return array> + */ + public function getEntityChangeSet() + { + return $this->entityChangeSet; + } + + /** + * Checks if field has a changeset. + * + * @return bool + */ + public function hasChangedField(string $field) + { + return isset($this->entityChangeSet[$field]); + } + + /** + * Gets the old value of the changeset of the changed field. + * + * @return mixed + */ + public function getOldValue(string $field) + { + $this->assertValidField($field); + + return $this->entityChangeSet[$field][0]; + } + + /** + * Gets the new value of the changeset of the changed field. + * + * @return mixed + */ + public function getNewValue(string $field) + { + $this->assertValidField($field); + + return $this->entityChangeSet[$field][1]; + } + + /** + * Sets the new value of this field. + * + * @param mixed $value + * + * @return void + */ + public function setNewValue(string $field, $value) + { + $this->assertValidField($field); + + $this->entityChangeSet[$field][1] = $value; + } + + /** + * Asserts the field exists in changeset. + * + * @return void + * + * @throws InvalidArgumentException + */ + private function assertValidField(string $field) + { + if (! isset($this->entityChangeSet[$field])) { + throw new InvalidArgumentException(sprintf( + 'Field "%s" is not a valid field of the entity "%s" in PreUpdateEventArgs.', + $field, + get_class($this->getObject()) + )); + } + } +} -- cgit v1.2.3