Class EventManager
The event manager is responsible for keeping track of event listeners, passing the correct data to them, and firing them in the correct order, when associated events are triggered. You can create multiple instances of this object to manage local events or keep a single instance and pass it around to manage all events in your app.
Properties summary
-  $_eventListprotectedThe event list object.Cake\Event\EventList|null
- The globally available instance, used for dispatching events attached from any scope
-  $_isGlobalprotectedInternal flag to distinguish a common manager from the singletonboolean
-  $_listenersprotectedList of listener callbacks associated toarray
-  $_trackEventsprotectedEnables automatic adding of events to the event list object if it is present.boolean
-   The default priority queue value for new, attached listenersinteger
Method Summary
-  __debugInfo() publicDebug friendly object properties.
-  _attachSubscriber() protectedAuxiliary function to attach all implemented callbacks of a Cake\Event\EventListenerInterface class instance as individual methods on this manager 
-  _callListener() protectedCalls a listener.
-  _detachSubscriber() protectedAuxiliary function to help detach all listeners provided by an object implementing EventListenerInterface
-  _extractCallable() protectedAuxiliary function to extract and return a PHP callback type out of the callable definition from the return value of the implementedEventsmethod on a Cake\Event\EventListenerInterface
-  addEventToList() publicAdds an event to the list if the event list object is present.
-  attach() publicAdds a new listener to an event.
-  detach() publicRemoves a listener from the active listeners.
-  dispatch() publicDispatches a new event to all configured listeners
-  getEventList() publicReturns the event list.
-    Returns the globally available instance of a Cake\Event\EventManager this is used for dispatching events attached from outside the scope other managers were created. Usually for creating hook systems or inter-class communication 
-  isTrackingEvents() publicReturns whether this manager is set up to track events
-  listeners() publicReturns a list of all listeners for an eventKey in the order they should be called
-  matchingListeners() publicReturns the listeners matching a specified pattern
-  off() publicRemove a listener from the active listeners.
-  on() publicAdds a new listener to an event.
-  prioritisedListeners() publicReturns the listeners for the specified event key indexed by priority
-  setEventList() publicEnables the listing of dispatched events.
-  trackEvents() publicEnables / disables event tracking at runtime.
-  unsetEventList() publicDisables the listing of dispatched events.
Method Detail
_attachSubscriber()source protected
_attachSubscriber( Cake\Event\EventListenerInterface $subscriber )
Auxiliary function to attach all implemented callbacks of a Cake\Event\EventListenerInterface class instance as individual methods on this manager
Parameters
-  Cake\Event\EventListenerInterface$subscriber
- Event listener.
_callListener()source protected
_callListener( callable $listener , Cake\Event\Event $event )
Calls a listener.
Parameters
-  callable $listener
- The listener to trigger.
-  Cake\Event\Event$event
- Event instance.
Returns
mixedThe result of the $listener function.
_detachSubscriber()source protected
_detachSubscriber( Cake\Event\EventListenerInterface $subscriber , string|null $eventKey null )
Auxiliary function to help detach all listeners provided by an object implementing EventListenerInterface
Parameters
-  Cake\Event\EventListenerInterface$subscriber
- the subscriber to be detached
-  string|null $eventKeyoptional null
- optional event key name to unsubscribe the listener from
_extractCallable()source protected
_extractCallable( array $function , Cake\Event\EventListenerInterface $object )
Auxiliary function to extract and return a PHP callback type out of the callable definition from the return value of the implementedEvents method on a Cake\Event\EventListenerInterface
Parameters
-  array $function
- the array taken from a handler definition for an event
-  Cake\Event\EventListenerInterface$object
- The handler object
Returns
callableaddEventToList()source public
addEventToList( Cake\Event\Event $event )
Adds an event to the list if the event list object is present.
Parameters
-  Cake\Event\Event$event
- An event to add to the list.
Returns
$this
attach()source public
attach( callable|Cake\Event\EventListenerInterface $callable , string|null $eventKey null , array $options [] )
Adds a new listener to an event.
Deprecated
3.0.0 Use on() instead.Parameters
-  callable|Cake\Event\EventListenerInterface$callable
- PHP valid callback type or instance of Cake\Event\EventListenerInterface to be called when the event named with $eventKey is triggered. If a Cake\Event\EventListenerInterface instance is passed, then the - implementedEventsmethod will be called on the object to register the declared events individually as methods to be managed by this class. It is possible to define multiple event handlers per event name.
-  string|null $eventKeyoptional null
- The event unique identifier name with which the callback will be associated. If $callable is an instance of Cake\Event\EventListenerInterface this argument will be ignored 
-  array $optionsoptional []
- used to set the - priorityflag to the listener. In the future more options may be added. Priorities are treated as queues. Lower values are called before higher ones, and multiple attachments added to the same priority queue will be treated in the order of insertion.
Throws
InvalidArgumentExceptionWhen event key is missing or callable is not an instance of Cake\Event\EventListenerInterface.
detach()source public
detach( callable|Cake\Event\EventListenerInterface $callable , string|null $eventKey null )
Removes a listener from the active listeners.
Deprecated
3.0.0 Use off() instead.Parameters
-  callable|Cake\Event\EventListenerInterface$callable
- any valid PHP callback type or an instance of EventListenerInterface
-  string|null $eventKeyoptional null
- The event unique identifier name with which the callback has been associated
dispatch()source public
dispatch( string|Cake\Event\Event $event )
Dispatches a new event to all configured listeners
Parameters
-  string|Cake\Event\Event$event
- the event key name or instance of Event
Returns
Cake\Event\EventTriggers
$eventinstance()source public static
instance( Cake\Event\EventManager|null $manager null )
Returns the globally available instance of a Cake\Event\EventManager this is used for dispatching events attached from outside the scope other managers were created. Usually for creating hook systems or inter-class communication
If called with the first parameter, it will be set as the globally available instance
Parameters
-  Cake\Event\EventManager|null$manageroptional null
- Event manager instance.
Returns
Cake\Event\EventManagerThe global event manager
isTrackingEvents()source public
isTrackingEvents( )
Returns whether this manager is set up to track events
Returns
booleanlisteners()source public
listeners( string $eventKey )
Returns a list of all listeners for an eventKey in the order they should be called
Parameters
-  string $eventKey
- Event key.
Returns
arraymatchingListeners()source public
matchingListeners( string $eventKeyPattern )
Returns the listeners matching a specified pattern
Parameters
-  string $eventKeyPattern
- Pattern to match.
Returns
arrayoff()source public
off( string|Cake\Event\EventListenerInterface $eventKey , callable|null $callable null )
Remove a listener from the active listeners.
Remove a EventListenerInterface entirely:
$manager->off($listener);
Remove all listeners for a given event:
$manager->off('My.event'); Remove a specific listener:
$manager->off('My.event', $callback); Remove a callback from all events:
$manager->off($callback);
Parameters
-  string|Cake\Event\EventListenerInterface$eventKey
- The event unique identifier name with which the callback has been associated, or the $listener you want to remove. 
-  callable|null $callableoptional null
- The callback you want to detach.
Returns
$this
on()source public
on( string|Cake\Event\EventListenerInterface|null $eventKey null , array|callable $options [] , callable|null $callable null )
Adds a new listener to an event.
A variadic interface to add listeners that emulates jQuery.on().
Binding an EventListenerInterface:
$eventManager->on($listener);
Binding with no options:
$eventManager->on('Model.beforeSave', $callable); Binding with options:
$eventManager->on('Model.beforeSave', ['priority' => 90], $callable); Parameters
-  string|Cake\Event\EventListenerInterface|null$eventKeyoptional null
- The event unique identifier name with which the callback will be associated. If $eventKey is an instance of Cake\Event\EventListenerInterface its events will be bound using the - implementedEventsmethods.
-  array|callable $optionsoptional []
- Either an array of options or the callable you wish to bind to $eventKey. If an array of options, the - prioritykey can be used to define the order. Priorities are treated as queues. Lower values are called before higher ones, and multiple attachments added to the same priority queue will be treated in the order of insertion.
-  callable|null $callableoptional null
- The callable function you want invoked.
Returns
$this
Throws
InvalidArgumentExceptionWhen event key is missing or callable is not an instance of Cake\Event\EventListenerInterface.
prioritisedListeners()source public
prioritisedListeners( string $eventKey )
Returns the listeners for the specified event key indexed by priority
Parameters
-  string $eventKey
- Event key.
Returns
arraysetEventList()source public
setEventList( Cake\Event\EventList $eventList )
Enables the listing of dispatched events.
Parameters
-  Cake\Event\EventList$eventList
- The event list object to use.
Returns
$this
trackEvents()source public
trackEvents( boolean $enabled )
Enables / disables event tracking at runtime.
Parameters
-  boolean $enabled
- True or false to enable / disable it.
Returns
$this
unsetEventList()source public
unsetEventList( )
Disables the listing of dispatched events.
Returns
$this
Properties detail
$_generalManagersource
 protected static Cake\Event\EventManager 
The globally available instance, used for dispatching events attached from any scope
$_isGlobalsource
protected boolean
Internal flag to distinguish a common manager from the singleton
false
$_trackEventssource
protected boolean
Enables automatic adding of events to the event list object if it is present.
false
$defaultPrioritysource
public static integer
The default priority queue value for new, attached listeners
10
    © 2005–2018 The Cake Software Foundation, Inc.
Licensed under the MIT License.
CakePHP is a registered trademark of Cake Software Foundation, Inc.
We are not endorsed by or affiliated with CakePHP.
    https://api.cakephp.org/3.5/class-Cake.Event.EventManager.html