From e30d7cfc036c354ee1b6255db287db1c9762b522 Mon Sep 17 00:00:00 2001 From: Michael Date: Sat, 10 Nov 2018 15:15:46 +0000 Subject: [PATCH] Add some hook to check if hook should be forked --- src/Core/Hook.php | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/src/Core/Hook.php b/src/Core/Hook.php index a0200a7db3..d221933dae 100644 --- a/src/Core/Hook.php +++ b/src/Core/Hook.php @@ -7,6 +7,7 @@ namespace Friendica\Core; use Friendica\App; use Friendica\BaseObject; use Friendica\Database\DBA; +use Friendica\Core\Logger; /** * Some functions to handle hooks @@ -136,6 +137,22 @@ class Hook extends BaseObject { if (array_key_exists($name, self::$hooks)) { foreach (self::$hooks[$name] as $hook) { + // Call a hook to check if this hook call needs to be forked + $hookdata = ['name' => $name, 'data' => $data, 'execute' => true]; + + if (array_key_exists('hook_fork', self::$hooks)) { + foreach (self::$hooks['hook_fork'] as $fork_hook) { + if ($hook[0] != $fork_hook[0]) { + continue; + } + self::callSingle(self::getApp(), 'hook_fork', $fork_hook, $hookdata); + } + } + + if (!$hookdata['execute']) { + continue; + } + Worker::add($priority, 'ForkHook', $name, $hook, $data); } } -- 2.39.5