From 9797a8b838e8895ef8731399940ddcd563dff03e Mon Sep 17 00:00:00 2001 From: Michel Mendiola Date: Tue, 24 Dec 2024 10:10:08 -0600 Subject: [PATCH 1/2] fix: Add a check to see if a file was already loaded --- Sources/ManageMaintenance.php | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/Sources/ManageMaintenance.php b/Sources/ManageMaintenance.php index b271082ebd..9676eb1666 100644 --- a/Sources/ManageMaintenance.php +++ b/Sources/ManageMaintenance.php @@ -2109,10 +2109,11 @@ function get_integration_hooks_data($start, $per_page, $sort, $filtered_hooks, $ foreach ($filtered_hooks as $hook => $functions) foreach ($functions as $rawFunc) { - $hookParsedData = parse_integration_hook($hook, $rawFunc); + $hookParsedData = parse_integration_hook($hook, $rawFunc, $function_list); // Handle hooks pointing outside the sources directory. $absPath_clean = rtrim($hookParsedData['absPath'], '!'); + if ($absPath_clean != '' && !isset($files[$absPath_clean]) && file_exists($absPath_clean)) $function_list += get_defined_functions_in_file($absPath_clean); @@ -2167,9 +2168,10 @@ function get_integration_hooks() * * @param string $hook * @param string $rawData A string as it was saved to the DB. + * @param array $functionList A list of functions found on previously parsed files * @return array everything found in the string itself */ -function parse_integration_hook(string $hook, string $rawData) +function parse_integration_hook(string $hook, string $rawData, array $functionList) { global $boarddir, $settings, $sourcedir; @@ -2227,6 +2229,18 @@ function parse_integration_hook(string $hook, string $rawData) else $hookData['call'] = $hookData['pureFunc'] = $modFunc; + $hookData['call'] = ltrim($hookData['call'], '\\'); + + // One last chance, perhaps the file was included in another way + if ($hookData['absPath'] === '' && isset($functionList[$hookData['call']])) + { + $hookData['absPath'] = strtr(strtr(trim($functionList[$hookData['call']]), [ + '$boarddir' => $boarddir, + '$sourcedir' => $sourcedir, + '$themedir' => $settings['theme_dir'] ?? '' + ]), '\\', '/'); + } + return $hookData; } From d538dd64e6bf542f42c77be69608e6ec93332dc8 Mon Sep 17 00:00:00 2001 From: Michel Mendiola Date: Thu, 26 Dec 2024 08:41:00 -0600 Subject: [PATCH 2/2] fix: just need to trim backslash --- Sources/ManageMaintenance.php | 15 ++------------- 1 file changed, 2 insertions(+), 13 deletions(-) diff --git a/Sources/ManageMaintenance.php b/Sources/ManageMaintenance.php index 9676eb1666..ed36a51609 100644 --- a/Sources/ManageMaintenance.php +++ b/Sources/ManageMaintenance.php @@ -2109,7 +2109,7 @@ function get_integration_hooks_data($start, $per_page, $sort, $filtered_hooks, $ foreach ($filtered_hooks as $hook => $functions) foreach ($functions as $rawFunc) { - $hookParsedData = parse_integration_hook($hook, $rawFunc, $function_list); + $hookParsedData = parse_integration_hook($hook, $rawFunc); // Handle hooks pointing outside the sources directory. $absPath_clean = rtrim($hookParsedData['absPath'], '!'); @@ -2168,10 +2168,9 @@ function get_integration_hooks() * * @param string $hook * @param string $rawData A string as it was saved to the DB. - * @param array $functionList A list of functions found on previously parsed files * @return array everything found in the string itself */ -function parse_integration_hook(string $hook, string $rawData, array $functionList) +function parse_integration_hook(string $hook, string $rawData) { global $boarddir, $settings, $sourcedir; @@ -2231,16 +2230,6 @@ function parse_integration_hook(string $hook, string $rawData, array $functionLi $hookData['call'] = ltrim($hookData['call'], '\\'); - // One last chance, perhaps the file was included in another way - if ($hookData['absPath'] === '' && isset($functionList[$hookData['call']])) - { - $hookData['absPath'] = strtr(strtr(trim($functionList[$hookData['call']]), [ - '$boarddir' => $boarddir, - '$sourcedir' => $sourcedir, - '$themedir' => $settings['theme_dir'] ?? '' - ]), '\\', '/'); - } - return $hookData; }