brick / event
Event dispatching library
Installs: 11 110
Dependents: 3
Suggesters: 0
Security: 0
Stars: 23
Watchers: 4
Forks: 3
Open Issues: 0
pkg:composer/brick/event
Requires
- php: >=7.1
Requires (Dev)
This package is auto-updated.
Last update: 2025-06-05 20:42:25 UTC
README
A simple event dispatching mechanism.
Introduction
This library helps to write extensible software by plugging in external listeners to events dispatched by an application.
Installation
This library is installable via Composer:
composer require brick/event
Requirements
This library requires PHP 7.1 or later.
Overview
This package provides the EventDispatcher.
The dispatcher dispatches events: an event is a unique string along with optional parameters.
The events are intercepted by listeners: any callable can be an event listener.
Basic usage
Let's instantiate a dispatcher:
use Brick\Event\EventDispatcher;
$dispatcher = new EventDispatcher();
And add a few listeners:
$dispatcher->addListener('startup', function() {
    echo 'Caught startup event';
});
$dispatcher->addListener('shutdown', function() {
    echo 'Caught shutdown event';
});
Now, let's dispatch some events:
$dispatcher->dispatch('startup'); // will display "Caught startup event"
$dispatcher->dispatch('shutdown'); // will display "Caught shutdown event"
Any additional parameters you pass to dispatch() are forwarded to the listeners:
$dispatcher->addListener('test', function($a, $b) {
    echo "Caught $a and $b";
});
$dispatcher->dispatch('test', 'Hello', 'World'); // will display "Caught Hello and World"
Setting priorities
By default, the listeners are called in the order they have been registered. It is possible to bypass this
natural order by passing a priority to addListener():
$dispatcher->addListener('startup', function() { ... }, 10);
The default priority is 0. The listeners with the highest priority will be called first in the chain.
Two listeners with the same priority will be called in the order they have been registered.
Stopping event propagation
Any listener can decide that the event should not be propagated to further listeners in the chain, by returning false:
$dispatcher->addListener('startup', function() {
    // ...
    return false;
});
The dispatcher will then break the chain and no further listeners will be called for this event.
