phalcon / incubator-events
Phalcon Incubator Events
Fund package maintenance!
phalcon
Open Collective
Requires
- php: >=7.2
- ext-phalcon: ^4.0
Requires (Dev)
- codeception/codeception: ^4.1
- codeception/module-asserts: ^1.0.0
- phalcon/ide-stubs: ^4.0
- phpstan/phpstan: ^0.12.18
- squizlabs/php_codesniffer: ^3.5
- vimeo/psalm: ^4.1
This package is auto-updated.
Last update: 2024-11-19 23:10:37 UTC
README
Usage examples of the features is here:
Manager
Classic event handling
Classic event handling requires one class with a bunch of methods named equal to event name.
And multiple $eventsManager->attach()
calls if you use more than one handler for single event:
class DispatchEventsHandler { public function beforeCallActionMethod( Phalcon\Events\EventInterface $event, Phalcon\Dispatcher\DispatcherInterface $dispatcher ): void { //do some stuff } public function beforeDoSomeMistakes( Phalcon\Events\EventInterface $event, Phalcon\Dispatcher\DispatcherInterface $dispatcher ): void { //do some right stuff } } class DispatchEventsHandlerTwo { public function beforeCallActionMethod( Phalcon\Events\EventInterface $event, Phalcon\Dispatcher\DispatcherInterface $dispatcher ): void { //do another stuff in same event } } $eventsManager = new Phalcon\Events\Manager(); $eventsManager->attach('dispatch:beforeCallActionMethod',new DispatchEventsHandler(), 100); $eventsManager->attach('dispatch:beforeCallActionMethod',new DispatchEventsHandlerTwo(), 101); $eventsManager->attach('dispatch:beforeDoSomeMistakes',new DispatchEventsHandler()); //or global way $eventsManager->attach('dispatch',new DispatchEventsHandler(), 100); $eventsManager->attach('dispatch',new DispatchEventsHandlerTwo(), 101);
Featured event handling
This manager version provides a feature of single responsible event handlers via configs, using __invoke
.
Create your handler class:
class BeforeCallActionMethod { public function __invoke( Phalcon\Events\EventInterface $event, Phalcon\Dispatcher\DispatcherInterface $dispatcher ): void { //do some stuff } }
Define configuration in config file:
$config = new Phalcon\Config([ 'handlers' => [ 'dispatch:beforeCallActionMethod' => BeforeCallActionMethod::class, ], ]);
Define Phalcon\Incubator\Events\Manager
in container as eventsManager service using config of handlers:
$handlers = $config->get('handlers')->toArray(); $eventsManager = new Phalcon\Incubator\Events\Manager(); $eventsManager->loadHandlers($handlers);
There are multiple ways to define configs of handlers:
Flat classname usage, if your handler is invokable:
$flat = new Phalcon\Config([ 'handlers' => [ 'dispatch:beforeCallActionMethod' => BeforeCallActionMethod::class, ], ]);
Same, but more informative and with optional priority:
$verbose = new Phalcon\Config([ 'handlers' => [ 'dispatch:beforeCallActionMethod' => [ 'class' => BeforeCallActionMethod::class, 'priority' => 100, //optional ], ], ]);
Using callable constructions:
$callable = new Phalcon\Config([ 'handlers' => [ //you can use any other public method name instead of method, for example run() 'dispatch:beforeCallActionMethod' => [new BeforeCallActionMethod(), 'run'], //or 'dispatch:beforeCallActionMethod' => [BeforeCallActionMethod::class, 'staticRun'], ], ]);
Grouping more than one handler for one event:
$grouped = new Phalcon\Config([ 'handlers' => [ 'dispatch:beforeCallActionMethod' => [ BeforeCallActionMethod::class, BeforeCallActionMethodAnother::class, BeforeCallActionMethodThird::class, ], ], ]); $groupedVerbose = new Phalcon\Config([ 'handlers' => [ 'dispatch:beforeCallActionMethod' => [ [ 'class' => BeforeCallActionMethod::class, 'priority' => 100, //optional ], [ 'class' => BeforeCallActionMethodAnother::class, 'priority' => 101, //optional ], [ 'class' => BeforeCallActionMethodThird::class, 'priority' => 101, //optional ], ], ], ]);