vendor/doctrine/orm/lib/Doctrine/ORM/Event/ListenersInvoker.php line 115

Open in your IDE?
  1. <?php
  2. /*
  3.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  4.  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  5.  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  6.  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  7.  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  8.  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  9.  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  10.  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  11.  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  12.  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  13.  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  14.  *
  15.  * This software consists of voluntary contributions made by many individuals
  16.  * and is licensed under the MIT license. For more information, see
  17.  * <http://www.doctrine-project.org>.
  18.  */
  19. namespace Doctrine\ORM\Event;
  20. use Doctrine\Common\EventArgs;
  21. use Doctrine\Common\EventManager;
  22. use Doctrine\ORM\EntityManagerInterface;
  23. use Doctrine\ORM\Mapping\ClassMetadata;
  24. use Doctrine\ORM\Mapping\EntityListenerResolver;
  25. /**
  26.  * A method invoker based on entity lifecycle.
  27.  */
  28. class ListenersInvoker
  29. {
  30.     public const INVOKE_NONE      0;
  31.     public const INVOKE_LISTENERS 1;
  32.     public const INVOKE_CALLBACKS 2;
  33.     public const INVOKE_MANAGER   4;
  34.     /** @var EntityListenerResolver The Entity listener resolver. */
  35.     private $resolver;
  36.     /**
  37.      * The EventManager used for dispatching events.
  38.      *
  39.      * @var EventManager
  40.      */
  41.     private $eventManager;
  42.     /**
  43.      * Initializes a new ListenersInvoker instance.
  44.      */
  45.     public function __construct(EntityManagerInterface $em)
  46.     {
  47.         $this->eventManager $em->getEventManager();
  48.         $this->resolver     $em->getConfiguration()->getEntityListenerResolver();
  49.     }
  50.     /**
  51.      * Get the subscribed event systems
  52.      *
  53.      * @param ClassMetadata $metadata  The entity metadata.
  54.      * @param string        $eventName The entity lifecycle event.
  55.      *
  56.      * @return int Bitmask of subscribed event systems.
  57.      */
  58.     public function getSubscribedSystems(ClassMetadata $metadata$eventName)
  59.     {
  60.         $invoke self::INVOKE_NONE;
  61.         if (isset($metadata->lifecycleCallbacks[$eventName])) {
  62.             $invoke |= self::INVOKE_CALLBACKS;
  63.         }
  64.         if (isset($metadata->entityListeners[$eventName])) {
  65.             $invoke |= self::INVOKE_LISTENERS;
  66.         }
  67.         if ($this->eventManager->hasListeners($eventName)) {
  68.             $invoke |= self::INVOKE_MANAGER;
  69.         }
  70.         return $invoke;
  71.     }
  72.     /**
  73.      * Dispatches the lifecycle event of the given entity.
  74.      *
  75.      * @param ClassMetadata $metadata  The entity metadata.
  76.      * @param string        $eventName The entity lifecycle event.
  77.      * @param object        $entity    The Entity on which the event occurred.
  78.      * @param EventArgs     $event     The Event args.
  79.      * @param int           $invoke    Bitmask to invoke listeners.
  80.      *
  81.      * @return void
  82.      */
  83.     public function invoke(ClassMetadata $metadata$eventName$entityEventArgs $event$invoke)
  84.     {
  85.         if ($invoke self::INVOKE_CALLBACKS) {
  86.             foreach ($metadata->lifecycleCallbacks[$eventName] as $callback) {
  87.                 $entity->$callback($event);
  88.             }
  89.         }
  90.         if ($invoke self::INVOKE_LISTENERS) {
  91.             foreach ($metadata->entityListeners[$eventName] as $listener) {
  92.                 $class    $listener['class'];
  93.                 $method   $listener['method'];
  94.                 $instance $this->resolver->resolve($class);
  95.                 $instance->$method($entity$event);
  96.             }
  97.         }
  98.         if ($invoke self::INVOKE_MANAGER) {
  99.             $this->eventManager->dispatchEvent($eventName$event);
  100.         }
  101.     }
  102. }