jakulov / event
Simple clear Event Dispatcher, compatible with Symfony Events
Requires
- jakulov/container: dev-master
- jakulov/corpuscle_log: dev-master
- jakulov/psr_event: dev-master
Requires (Dev)
- phpunit/phpunit: ^5.1
This package is not auto-updated.
Last update: 2025-01-18 20:13:57 UTC
README
Simple & clear PHP Event Dispatcher, compatible with Symfony Events
Can be installed with composer
composer require jakulov/event
Implements Symfony Event Interfaces
1. Dispatcher
There's three common ways to register listeners: setConfig, addListener and use Subscriber class. Config could look like this:
$listener1 = new \Listener\TestListener();
$listener2 = new \Listener\TestPrioritizedListener();
$config = [
'event.test' => [ // the name of event
[$listener1, 'onTest', 1], // listener, method and priority
[$listener2, 'onTest'],
],
'event.another_test' => [
['@service.listener', 'onAnotherTest'], // you can use reference to DIContainer service
],
];
$dispatcher = new \jakulov\Event\EventDispatcher();
$dispatcher->setConfig($config);
Link to container library: jakulov/container
Using addListener is more usual way:
$listener = [new \Listener\TestListener(), 'onTest'];
$dispatcher = new \jakulov\Event\EventDispatcher();
$dispatcher->addListener($event->getName(), $listener);
Also dispatcher requires a Logger instance, implementing Psr Log If don't need in logging events, just do this:
$dispatcher = new \jakulov\Event\EventDispatcher();
$dispatcher->setLogger(new \Psr\Log\NullLogger());
2. Subscriber
Using subscriber class is usual way to setup multiple event listeners at once:
$dispatcher = new \jakulov\Event\EventDispatcher();
$dispatcher->addSubscriber(new \Listener\TestSubscriber());
3. Event
Class \jakulov\Event\AbstractEvent should be parent for all event objects used with dispatcher. You can dispatch events without event object, but objects is the right way to pass event data to listeners.
Tests
Run: ./run_tests.sh
Tests are also examples for usage library