mirror of
https://github.com/nextcloud/server.git
synced 2024-12-29 16:38:28 +00:00
1a4978c4ea
Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>
105 lines
3.5 KiB
PHP
105 lines
3.5 KiB
PHP
<?php
|
|
/**
|
|
* SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
namespace OCA\WorkflowEngine\AppInfo;
|
|
|
|
use Closure;
|
|
use OCA\WorkflowEngine\Helper\LogContext;
|
|
use OCA\WorkflowEngine\Listener\LoadAdditionalSettingsScriptsListener;
|
|
use OCA\WorkflowEngine\Manager;
|
|
use OCA\WorkflowEngine\Service\Logger;
|
|
use OCP\AppFramework\App;
|
|
use OCP\AppFramework\Bootstrap\IBootContext;
|
|
use OCP\AppFramework\Bootstrap\IBootstrap;
|
|
use OCP\AppFramework\Bootstrap\IRegistrationContext;
|
|
use OCP\EventDispatcher\Event;
|
|
use OCP\EventDispatcher\IEventDispatcher;
|
|
use OCP\WorkflowEngine\Events\LoadSettingsScriptsEvent;
|
|
use OCP\WorkflowEngine\IEntity;
|
|
use OCP\WorkflowEngine\IOperation;
|
|
use Psr\Container\ContainerExceptionInterface;
|
|
use Psr\Container\ContainerInterface;
|
|
use Psr\Log\LoggerInterface;
|
|
|
|
class Application extends App implements IBootstrap {
|
|
public const APP_ID = 'workflowengine';
|
|
|
|
public function __construct() {
|
|
parent::__construct(self::APP_ID);
|
|
}
|
|
|
|
public function register(IRegistrationContext $context): void {
|
|
$context->registerEventListener(
|
|
LoadSettingsScriptsEvent::class,
|
|
LoadAdditionalSettingsScriptsListener::class,
|
|
-100
|
|
);
|
|
}
|
|
|
|
public function boot(IBootContext $context): void {
|
|
$context->injectFn(Closure::fromCallable([$this, 'registerRuleListeners']));
|
|
}
|
|
|
|
private function registerRuleListeners(IEventDispatcher $dispatcher,
|
|
ContainerInterface $container,
|
|
LoggerInterface $logger): void {
|
|
/** @var Manager $manager */
|
|
$manager = $container->get(Manager::class);
|
|
$configuredEvents = $manager->getAllConfiguredEvents();
|
|
|
|
foreach ($configuredEvents as $operationClass => $events) {
|
|
foreach ($events as $entityClass => $eventNames) {
|
|
array_map(function (string $eventName) use ($manager, $container, $dispatcher, $logger, $operationClass, $entityClass): void {
|
|
$dispatcher->addListener(
|
|
$eventName,
|
|
function ($event) use ($manager, $container, $eventName, $logger, $operationClass, $entityClass): void {
|
|
$ruleMatcher = $manager->getRuleMatcher();
|
|
try {
|
|
/** @var IEntity $entity */
|
|
$entity = $container->get($entityClass);
|
|
/** @var IOperation $operation */
|
|
$operation = $container->get($operationClass);
|
|
|
|
$ruleMatcher->setEventName($eventName);
|
|
$ruleMatcher->setEntity($entity);
|
|
$ruleMatcher->setOperation($operation);
|
|
|
|
$ctx = new LogContext();
|
|
$ctx
|
|
->setOperation($operation)
|
|
->setEntity($entity)
|
|
->setEventName($eventName);
|
|
|
|
/** @var Logger $flowLogger */
|
|
$flowLogger = $container->get(Logger::class);
|
|
$flowLogger->logEventInit($ctx);
|
|
|
|
if ($event instanceof Event) {
|
|
$entity->prepareRuleMatcher($ruleMatcher, $eventName, $event);
|
|
$operation->onEvent($eventName, $event, $ruleMatcher);
|
|
} else {
|
|
$logger->debug(
|
|
'Cannot handle event {name} of {event} against entity {entity} and operation {operation}',
|
|
[
|
|
'app' => self::APP_ID,
|
|
'name' => $eventName,
|
|
'event' => get_class($event),
|
|
'entity' => $entityClass,
|
|
'operation' => $operationClass,
|
|
]
|
|
);
|
|
}
|
|
$flowLogger->logEventDone($ctx);
|
|
} catch (ContainerExceptionInterface $e) {
|
|
// Ignore query exceptions since they might occur when an entity/operation were set up before by an app that is disabled now
|
|
}
|
|
}
|
|
);
|
|
}, $eventNames ?? []);
|
|
}
|
|
}
|
|
}
|
|
}
|