86cdaa7c3c
Support service/method tuples as indexable callbacks. Closures are also supported, although they cannot be injected by the service container. The indexable callback is now injected via a setter and validated when set (instead of during event processing).
51 lines
1.4 KiB
PHP
51 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace FOQ\ElasticaBundle\Doctrine\ORM;
|
|
|
|
use Doctrine\ORM\Event\LifecycleEventArgs;
|
|
use FOQ\ElasticaBundle\Doctrine\AbstractListener;
|
|
|
|
class Listener extends AbstractListener
|
|
{
|
|
public function postPersist(LifecycleEventArgs $eventArgs)
|
|
{
|
|
$entity = $eventArgs->getEntity();
|
|
|
|
if ($entity instanceof $this->objectClass && $this->isObjectIndexable($entity)) {
|
|
$this->objectPersister->insertOne($entity);
|
|
}
|
|
}
|
|
|
|
public function postUpdate(LifecycleEventArgs $eventArgs)
|
|
{
|
|
$entity = $eventArgs->getEntity();
|
|
|
|
if ($entity instanceof $this->objectClass) {
|
|
if ($this->isObjectIndexable($entity)) {
|
|
$this->objectPersister->replaceOne($entity);
|
|
} else {
|
|
$this->scheduleForRemoval($entity, $eventArgs->getEntityManager());
|
|
$this->removeIfScheduled($entity);
|
|
}
|
|
}
|
|
}
|
|
|
|
public function preRemove(LifecycleEventArgs $eventArgs)
|
|
{
|
|
$entity = $eventArgs->getEntity();
|
|
|
|
if ($entity instanceof $this->objectClass) {
|
|
$this->scheduleForRemoval($entity, $eventArgs->getEntityManager());
|
|
}
|
|
}
|
|
|
|
public function postRemove(LifecycleEventArgs $eventArgs)
|
|
{
|
|
$entity = $eventArgs->getEntity();
|
|
|
|
if ($entity instanceof $this->objectClass) {
|
|
$this->removeIfScheduled($entity);
|
|
}
|
|
}
|
|
}
|