Download the PHP package silverstripe/event-dispatcher without Composer
On this page you can find all versions of the php package silverstripe/event-dispatcher. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download silverstripe/event-dispatcher
More information about silverstripe/event-dispatcher
Files in silverstripe/event-dispatcher
Package event-dispatcher
Short Description Publish and subscribe to events in Silverstripe CMS or your Silverstripe application
License BSD-3-Clause
Informations about the package event-dispatcher
Event dispatcher for Silverstripe CMS
This module provides a PSR-14 event dispatcher to Silverstripe CMS
applications. It is useful for reactive programming
paradigms in lieu of traditional imperative designs through hooks like onAfterWrite
.
Most of the underlying work is handled by Symfony's EventDispatcher, but this can be replaced with through dependency injection.
Requirements
- silverstripe/framework: ^4.5
Installation
$ composer require silverstripe/event-dispatcher
Usage
There are three main components to the API:
- The
Dispatcher
is responsible for registering event listeners and triggering events Listeners
are classes that trigger events, typically via extension hooksHandlers
are classes that execute code in response to an event.
Dispatching an event
The trigger
function takes two arguments: string $eventName
and EventContextInterface $context
. The $context
object can pass arbitrary data to any handlers that are subscribed to the event.
Event handling
Event handlers must implement EventHandlerInterface
, which requires a fire()
method.
Subscribing to events
The best way to register your event handlers with the dispatcher is through config.
Unsubscribing to events
To remove an event handler, override the config with an off
node.
Managing events procedurally
To interact with the Dispatcher
instance directly, use a DispatcherLoaderInterface
.
Then, register the loader in Injector
.
Action identifiers and context
Each of these handlers is passed a context object that exposes an action identifier. This is a string that
provides specific information about what happened in the event that the handler can then use in its implementation.
For instance, if you want to write event handlers for form submissions, where some handlers are for all form submissions,
while others are for specific forms, you might pass the name of the form as an action identifier in your EventContext
object.
Events are always called with eventName.<action identifier>
. For instance formSubmitted.contact
, allowing
the subscribers to only react to a specific subset of events.
In this case, a contact form submission results in two handlers firing, in order of specificity (formSubmitted.contact
first).
How to find your action identifier
The easiest way to debug events is to put breakpoints or logging into the Dispatcher::trigger()
function. This
will provide all the detail you need about what events are triggered when, and with what context.
When the logging is in place you just go to the CMS and perform the action you are interested in. This should narrow the list of identifier down to a much smaller subset.
Event context
In the above example, the contact form data is passed to the Event
object as context.
In a handler, this can be accessed using the get(string $property)
method.
Note that get
fails gracefully, and will return null
when a property doesn't exist.
License
See License
Bugtracker
Bugs are tracked in the issues section of this repository. Before submitting an issue please read over existing issues to ensure yours is unique.
If the issue does look like a new bug:
- Create a new issue
- Describe the steps required to reproduce your issue, and the expected outcome. Unit tests, screenshots and screencasts can help here.
- Describe your environment as detailed as possible: Silverstripe version, Browser, PHP version, Operating System, any installed Silverstripe modules.
Please report security issues to the module maintainers directly. Please don't file security issues in the bugtracker.
Development and contribution
If you would like to make contributions to the module please ensure you raise a pull request and discuss with the module maintainers.
All versions of event-dispatcher with dependencies
silverstripe/framework Version ^5
symfony/event-dispatcher Version ^6.1
psr/event-dispatcher Version ^1