2017 © Pedro Peláez
 

library radiate

Radiate event emitter

image

acairns/radiate

Radiate event emitter

  • Friday, September 30, 2016
  • by acairns
  • Repository
  • 0 Watchers
  • 1 Stars
  • 9,255 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 2 Forks
  • 0 Open issues
  • 4 Versions
  • 28 % Grown

The README.md

Radiate

Build Status Scrutinizer Code Quality Code Coverage, (*1)


Introduction

Radiate is a package for managing Events., (*2)

Basic Usage

Simply create an instance of the Emitter and emit events!, (*3)

$emitter new Emitter($middleware);
$emitter->emit(new ExampleEvent);

Creating the Emitter

Radiate requires a pipeline of middleware when being created. The main middleware required to invoke listeners is an instance of the InvokeListenerMiddleware class., (*4)

use Cairns\Radiate\Emitter;
use Cairns\Radiate\Inflector\HandleMethodInflector;
use Cairns\Radiate\Middleware\InvokeListenerMiddleware;

$invoker = new InvokeListenerMiddleware(
    $registry,
    $locator,
    $inflector
);

$emitter = new Cairns\Radiate\Emitter([
    $invoker
]);

In order to invoke a Listener, the middleware needs to know the available Listeners ($registry), how to create an instance of the subscribed Listeners ($locator) and how to determine which method should be invoked ($inflector)., (*5)

Registrys

A Registry is a simple class responsible of keeping track all of the subscribed Listeners., (*6)

Locators

The responsibility of the locator is to take a Fully Qualified Class Name for a Listener and to return an instance. If you are using a Dependency Injection container, then this is where you want to resolve the concrete instance., (*7)

Inflectors

The job of the inflector is to determine which method should be called on a particular Listener given a specific Event. Several Inflectors are provided for common setups., (*8)

HandleMethodInflector

The HandleMethodInflector ensures the handle() method is returned. A Listener could look like this:, (*9)

final class DisableTransporters
{
    public function handle(WarpDriveEngaged $event)
    {
        // Do Something
    }
}

TypehintMethodInflector

The TypehintMethodInflector ensures any method dependent on the type of event is returned. A Listener could look like this:, (*10)

final class DisableTransporters
{
    public function whenWarpDriveEngaged(WarpDriveEngaged $event)
    {
        // Do Something
    }

    public function whenShieldsWereRaised(ShieldsWereRaised $event)
    {
        // Do Something
    }
}

When using the TypehintMethodInflector, you can define multiple public methods so that the same Listener can respond to different events., (*11)

Simple Example

final class WarpDriveEngaged
{
    private $speed;

    public function __construct($speed)
    {
        $this->speed = $speed;
    }

    public function getSpeed()
    {
        return $this->speed;
    }
}

final class DisableTransporters
{
    public function whenWarpDriveIsEngaged(WarpDriveEngaged $event)
    {
        // safety first!
    }
}

$registry = new \Cairns\Radiate\Registry\TypehintedClassRegistry;
$registry->register(DisableTransporters::class);

$locator = new Cairns\Radiate\Locator\InMemoryListenerLocator;
$locator->add(new DisableTransporters);

$invoker = new \Cairns\Radiate\Middleware\InvokeListenerMiddleware(
    $registry,
    $locator,
    new Cairns\Radiate\Inflector\TypehintMethodInflector
);

$emitter = new Cairns\Radiate\Emitter([
    $invoker
]);

$emitter->emit(new WarpDriveEngaged(9));

Inspiration

This library is inspired by:, (*12)

Contributing

Even though this is just an experiment for now, I'm totally open to ideas. Shoot over a PR!, (*13)

If you decide to help out, here are some helpful things to check:, (*14)

Running tests

$ ./vendor/bin/phpunit

Code Sniffer

$ ./vendor/bin/phpcs --standard=PSR2 ./src/

Todo

  • [ ] Bump to >=PHP7, update codebase (return types, typehint, etc.)
  • [ ] Extract examples into example directory
  • [ ] Make registry serialisable, and constructable from a serialised registry

The Versions

30/09 2016

dev-master

9999999-dev

Radiate event emitter

  Sources   Download

MIT

The Requires

  • php >=7.0.0

 

The Development Requires

emitter event listener

30/09 2016

0.1.2

0.1.2.0

Radiate event emitter

  Sources   Download

MIT

The Requires

  • php >=7.0.0

 

The Development Requires

emitter event listener

26/09 2016

0.1.1

0.1.1.0

Radiate event emitter

  Sources   Download

MIT

The Requires

  • php >=7.0.0

 

The Development Requires

emitter event listener

26/09 2016

0.1.0

0.1.0.0

Radiate event emitter

  Sources   Download

MIT

The Requires

  • php >=7.0.0

 

The Development Requires

emitter event listener