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

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\ORM\EntityManagerInterface;
  22. use Doctrine\ORM\Mapping\ClassMetadata;
  23. /**
  24.  * A method invoker based on entity lifecycle.
  25.  *
  26.  * @author  Fabio B. Silva <fabio.bat.silva@gmail.com>
  27.  * @since   2.4
  28.  */
  29. class ListenersInvoker
  30. {
  31.     const INVOKE_NONE       0;
  32.     const INVOKE_LISTENERS  1;
  33.     const INVOKE_CALLBACKS  2;
  34.     const INVOKE_MANAGER    4;
  35.     /**
  36.      * @var \Doctrine\ORM\Mapping\EntityListenerResolver The Entity listener resolver.
  37.      */
  38.     private $resolver;
  39.     /**
  40.      * The EventManager used for dispatching events.
  41.      *
  42.      * @var \Doctrine\Common\EventManager
  43.      */
  44.     private $eventManager;
  45.     /**
  46.      * Initializes a new ListenersInvoker instance.
  47.      *
  48.      * @param EntityManagerInterface $em
  49.      */
  50.     public function __construct(EntityManagerInterface $em)
  51.     {
  52.         $this->eventManager $em->getEventManager();
  53.         $this->resolver     $em->getConfiguration()->getEntityListenerResolver();
  54.     }
  55.     /**
  56.      * Get the subscribed event systems
  57.      *
  58.      * @param \Doctrine\ORM\Mapping\ClassMetadata $metadata  The entity metadata.
  59.      * @param string                              $eventName The entity lifecycle event.
  60.      *
  61.      * @return integer Bitmask of subscribed event systems.
  62.      */
  63.     public function getSubscribedSystems(ClassMetadata $metadata$eventName)
  64.     {
  65.         $invoke self::INVOKE_NONE;
  66.         if (isset($metadata->lifecycleCallbacks[$eventName])) {
  67.             $invoke |= self::INVOKE_CALLBACKS;
  68.         }
  69.         if (isset($metadata->entityListeners[$eventName])) {
  70.             $invoke |= self::INVOKE_LISTENERS;
  71.         }
  72.         if ($this->eventManager->hasListeners($eventName)) {
  73.             $invoke |= self::INVOKE_MANAGER;
  74.         }
  75.         return $invoke;
  76.     }
  77.     /**
  78.      * Dispatches the lifecycle event of the given entity.
  79.      *
  80.      * @param \Doctrine\ORM\Mapping\ClassMetadata $metadata  The entity metadata.
  81.      * @param string                              $eventName The entity lifecycle event.
  82.      * @param object                              $entity    The Entity on which the event occurred.
  83.      * @param \Doctrine\Common\EventArgs          $event     The Event args.
  84.      * @param integer                             $invoke    Bitmask to invoke listeners.
  85.      */
  86.     public function invoke(ClassMetadata $metadata$eventName$entityEventArgs $event$invoke)
  87.     {
  88.         if ($invoke self::INVOKE_CALLBACKS) {
  89.             foreach ($metadata->lifecycleCallbacks[$eventName] as $callback) {
  90.                 $entity->$callback($event);
  91.             }
  92.         }
  93.         if ($invoke self::INVOKE_LISTENERS) {
  94.             foreach ($metadata->entityListeners[$eventName] as $listener) {
  95.                 $class      $listener['class'];
  96.                 $method     $listener['method'];
  97.                 $instance   $this->resolver->resolve($class);
  98.                 $instance->$method($entity$event);
  99.             }
  100.         }
  101.         if ($invoke self::INVOKE_MANAGER) {
  102.             $this->eventManager->dispatchEvent($eventName$event);
  103.         }
  104.     }
  105. }