Download the PHP package heybigname/event-dispatcher without Composer
On this page you can find all versions of the php package heybigname/event-dispatcher. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download heybigname/event-dispatcher
More information about heybigname/event-dispatcher
Files in heybigname/event-dispatcher
Package event-dispatcher
Short Description Event Dispatcher with a focus on Domain Events
License MIT
Informations about the package event-dispatcher
Domain Event Dispatcher
An Event Dispatcher built with a focus on Domain Events.
Table of Contents
- Installation
- Integrations
- Laravel
- How It Works
- Event
- Listener
- Listening
- Lazy Listening
- Dispatching Multiple Events
- Maintainers
- License
Installation
Run the command below to install via Composer
Integrations
Although this package is completely framework agnostic, it does have integrations with framework(s). Currently only Laravel 4.x is included, but if requested others can be added.
Laravel
To install into a Laravel project, first do the composer install then add the following class to your config/app.php
service providers list.
That's all it takes for the Laravel integration. Now it's possible to inject or make a Dispatcher like this:
How It Works
Event
In your domain you'll create an event, for let's say when a new member has been registered.
Lets call this event MemberWasRegistered
. This event will hold the necessary information for the listener to fulfill it's job.
You have complete freedom about which arguments it takes, since you'll be the one passing them in.
In some ways this event is a Data Transfer Object
(DTO).
For example:
Listener
An event without a listener does no good for us, so lets create an email listener WelcomeNewlyRegisteredMemberListener
for the event MemberWasRegistered
.
Same rule with the listeners as the events, you have complete freedom with the arguments.
When an event is dispatched the handle
method on the correct listeners will be called.
Listening
Now we got the building blocks ready lets start listening for some new members, shall we. For the sake of this example, the code is kept as simple as possible.
Lazy Listening
It's possible to have your listeners lazy loaded. Merely pass a string with full namespace of the class. Currently this only works with the Laravel (Illuminate) Container. Other containers can be supported, if requested.
This will construct and instantiate the listener(s) on dispatch()
or getLazyListeners()
.
Lazy loading listeners can help mitigate the overhead if you have all your listeners instantiated on bootstrap.
Dispatching Multiple Events
For extra hipster points you can dispatch multiple events in 1 call.
Maintainers
This package is maintained by Mitchell van Wijngaarden of Big Name
License
This package is licensed under the MIT license.