scones / nexus
implementation for the upcoming PSR-14 standard. currently supporting 0.6.0
0.6.1
2019-05-28 11:49 UTC
Requires
- php: ~7.2
- psr/event-dispatcher: ^0.6.0, <1.0.0
- psr/event-dispatcher-message: ^0.6.0
- psr/event-dispatcher-task: ^0.6.0
Requires (Dev)
- phploc/phploc: *@stable
- phpmd/phpmd: *@stable
- phpunit/phpunit: *@stable
- sebastian/phpcpd: *@stable
Provides
This package is auto-updated.
Last update: 2024-10-28 23:26:17 UTC
README
Nexus
psr-14 event dispatcher implementation
(honoring psr-12)
Install
In most cases it should suffice to just install it via composer.
composer require scones/nexus "*@stable"
Usage
These exmaples are taken from the tests, so there is of course a bit of redundancy.
Messages
The usage is quite basic.
- You define a Message class.
- You provide a callable listener with one argument, which has to match the Message Type it should listen on.
- You call the notfier with an instance of the Message you wish to propagate
use Psr\EventDispatcher\MessageInterface; use Nexus\StandardListenerProvider; use Nexus\SynchronousNotifier; class SomeMessage implements MessageInterface { } class SomeOtherMessage implements MessageInterface { } $provider = new StandardListenerProvider(); $notifier = new SynchronousNotifier($provider); $provider->addListener(function (SomeMessage $someMessage) { echo "some cool message reaction code goes here\n"; }); $provider->addListener(function (SomeMessage $someMessage) { echo "this message seems worth logging!\n"; }); $provider->addListener(function (SomeOtherMessage $someOtherMessage) { echo "oh, the other message was dispatched!\n"; }); $testMessage = new SomeMessage(); $notifier->notify($testMessage);
which would of course result in:
some cool message reaction code goes here
this message seems worth logging!
Tasks
Again the usage is quite simplistic.
- You define a Task class.
- You provide a callable listener with one argument, which has to match the Task Type it should listen on.
- You call the processor with an instance of the Task you wish to propagate
- After all Tasks have processed, the resulting modified task instance is returned.
use Nexus\StandardListenerProvider; use Nexus\SynchronousProcessor; use Psr\EventDispatcher\TaskInterface; class SomeTask implements TaskInterface { private $accessCounter = 0; public function increaseCounter(): void { $this->accessCounter++; } public function getCounter(): int { return $this->accessCounter; } } class SomeOtherTask implements TaskInterface { } $provider = new StandardListenerProvider(); $processor = new SynchronousProcessor($provider); $provider->addListener(function (SomeTask $someTask) { echo "some task working!\n"; $someTask->increaseCounter(); return $someTask; }); $provider->addListener(function (SomeTask $someTask) { echo "some task working again!\n"; $someTask->increaseCounter(); $someTask->increaseCounter(); return $someTask; }); $provider->addListener(function (SomeOtherTask $someOtherTask) { echo "the other Task!"; return $someOtherTask; }); $testTask = new SomeTask(); $testTaskResult = $processor->process($testTask); echo "task result was: {$testTaskResult->getCounter()}\n";
which would of course result in:
some task working!
some task working again!
task result was: 3