primo commit
This commit is contained in:
@ -0,0 +1,149 @@
|
||||
<?php
|
||||
/**
|
||||
* @package AllediaFramework
|
||||
* @contact www.joomlashack.com, help@joomlashack.com
|
||||
* @copyright 2022-2023 Joomlashack.com. All rights reserved
|
||||
* @license https://www.gnu.org/licenses/gpl.html GNU/GPL
|
||||
*
|
||||
* This file is part of AllediaFramework.
|
||||
*
|
||||
* AllediaFramework is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation, either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* AllediaFramework is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with AllediaFramework. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
namespace Alledia\Framework\Joomla\Events;
|
||||
|
||||
use Alledia\Framework\Factory;
|
||||
use Joomla\Event\AbstractEvent;
|
||||
use Joomla\Event\Dispatcher;
|
||||
|
||||
defined('_JEXEC') or die();
|
||||
|
||||
trait TraitObservable
|
||||
{
|
||||
/**
|
||||
* @var \JEventDispatcher|Dispatcher
|
||||
*/
|
||||
protected static $coreDispatcher = null;
|
||||
|
||||
/**
|
||||
* @var bool
|
||||
*/
|
||||
protected static $legacyDispatch = null;
|
||||
|
||||
/**
|
||||
* @return \JEventDispatcher|Dispatcher
|
||||
*/
|
||||
public function getDispatcher()
|
||||
{
|
||||
if (static::$coreDispatcher === null) {
|
||||
static::$coreDispatcher = Factory::getDispatcher();
|
||||
static::$legacyDispatch = is_callable([static::$coreDispatcher, 'register']);
|
||||
}
|
||||
|
||||
return static::$coreDispatcher;
|
||||
}
|
||||
|
||||
/**
|
||||
* $events is accepted in these forms:
|
||||
*
|
||||
* ['handler1', 'handler2',...]: array of specific methods to register
|
||||
* 'handler' : a single method to register
|
||||
* 'prefix*' : all public methods in $observable that begin with 'prefix'
|
||||
* '*string' : all public methods in $observable that contain 'string'
|
||||
*
|
||||
* @param string|string[] $events
|
||||
* @param ?object $observable
|
||||
* @param ?bool $legacyListeners
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function registerEvents($events, object $observable = null, bool $legacyListeners = true): void
|
||||
{
|
||||
$observable = $observable ?: $this;
|
||||
|
||||
if (is_string($events) && strpos($events, '*') !== false) {
|
||||
$startsWith = strpos($events, '*') !== 0;
|
||||
$event = preg_replace('/[^a-z\d_]/i', '', $events);
|
||||
|
||||
// Look for methods that match the wildcarded name
|
||||
$observableInfo = new \ReflectionClass($observable);
|
||||
$methods = $observableInfo->getMethods(\ReflectionMethod::IS_PUBLIC);
|
||||
|
||||
$events = [];
|
||||
foreach ($methods as $method) {
|
||||
$position = strpos($method->name, $event);
|
||||
if (
|
||||
($startsWith && $position === 0)
|
||||
|| ($startsWith == false && $position > 0)
|
||||
) {
|
||||
$events[] = $method->name;
|
||||
}
|
||||
}
|
||||
|
||||
} elseif (is_string($events)) {
|
||||
$events = [$events];
|
||||
}
|
||||
|
||||
if ($events && is_array($events)) {
|
||||
$dispatcher = Factory::getDispatcher();
|
||||
foreach ($events as $event) {
|
||||
$handler = [$observable, $event];
|
||||
if (is_callable([$dispatcher, 'register'])) {
|
||||
$dispatcher->register($event, $handler);
|
||||
} elseif (is_callable([$dispatcher, 'addListener'])) {
|
||||
if ($legacyListeners) {
|
||||
$dispatcher->addListener($event, $this->createLegacyHandler($handler));
|
||||
} else {
|
||||
$dispatcher->addListener($event, $handler);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param callable $handler
|
||||
*
|
||||
* @return callable
|
||||
*/
|
||||
final protected function createLegacyHandler(callable $handler): callable
|
||||
{
|
||||
return function (AbstractEvent $event) use ($handler) {
|
||||
$arguments = $event->getArguments();
|
||||
|
||||
// Extract any old results; they must not be part of the method call.
|
||||
$allResults = [];
|
||||
|
||||
if (isset($arguments['result'])) {
|
||||
$allResults = $arguments['result'];
|
||||
|
||||
unset($arguments['result']);
|
||||
}
|
||||
|
||||
// Convert to indexed array for unpacking.
|
||||
$arguments = \array_values($arguments);
|
||||
|
||||
$result = $handler(...$arguments);
|
||||
|
||||
// Ignore null results
|
||||
if ($result === null) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Restore the old results and add the new result from our method call
|
||||
$allResults[] = $result;
|
||||
$event['result'] = $allResults;
|
||||
};
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user