phalcon/incubator-events
Composer 安装命令:
composer require phalcon/incubator-events
包简介
Phalcon Incubator Events
README 文档
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 ], ], ], ]);
统计信息
- 总下载量: 50
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 4
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: BSD-3-Clause
- 更新时间: 2020-09-05