| Current Path : /home/rtorresani/www/vendor/laminas/laminas-eventmanager/src/ |
| Current File : //home/rtorresani/www/vendor/laminas/laminas-eventmanager/src/EventManagerAwareTrait.php |
<?php
namespace Laminas\EventManager;
use Traversable;
use function array_merge;
use function array_unique;
use function is_array;
use function is_object;
use function is_string;
use function method_exists;
/**
* A trait for objects that provide events.
*
* If you use this trait in an object, you will probably want to also implement
* EventManagerAwareInterface, which will make it so the default initializer in
* a Laminas MVC application will automatically inject an instance of the
* EventManager into your object when it is pulled from the ServiceManager.
*
* @see Laminas\Mvc\Service\ServiceManagerConfig
*/
trait EventManagerAwareTrait
{
/** @var EventManagerInterface */
protected $events;
/**
* Set the event manager instance used by this context.
*
* For convenience, this method will also set the class name / LSB name as
* identifiers, in addition to any string or array of strings set to the
* $this->eventIdentifier property.
*/
public function setEventManager(EventManagerInterface $events)
{
$identifiers = [self::class, static::class];
if (isset($this->eventIdentifier)) {
if (
(is_string($this->eventIdentifier))
|| (is_array($this->eventIdentifier))
|| $this->eventIdentifier instanceof Traversable
) {
$identifiers = array_unique(array_merge($identifiers, (array) $this->eventIdentifier));
} elseif (is_object($this->eventIdentifier)) {
$identifiers[] = $this->eventIdentifier;
}
// silently ignore invalid eventIdentifier types
}
$events->setIdentifiers($identifiers);
$this->events = $events;
if (method_exists($this, 'attachDefaultListeners')) {
$this->attachDefaultListeners();
}
}
/**
* Retrieve the event manager
*
* Lazy-loads an EventManager instance if none registered.
*
* @return EventManagerInterface
*/
public function getEventManager()
{
if (! $this->events instanceof EventManagerInterface) {
$this->setEventManager(new EventManager());
}
return $this->events;
}
}