From 4b33a71e998cdc396bc312b20ca4e22f59dc5282 Mon Sep 17 00:00:00 2001 From: Alex Rock Ancelet Date: Thu, 19 Dec 2024 16:57:18 +0100 Subject: [PATCH 1/2] Move db update check out of StandardIncludes to its own listener+controller --- .../LegacyConfigurators/StandardIncludes.php | 8 -- src/Glpi/Controller/NeedsUpdateController.php | 129 ++++++++++++++++++ .../Listener/CheckIfUpdateNeededListener.php | 74 ++++++++++ src/Glpi/Kernel/ListenersPriority.php | 4 + 4 files changed, 207 insertions(+), 8 deletions(-) create mode 100644 src/Glpi/Controller/NeedsUpdateController.php create mode 100644 src/Glpi/Http/Listener/CheckIfUpdateNeededListener.php diff --git a/src/Glpi/Config/LegacyConfigurators/StandardIncludes.php b/src/Glpi/Config/LegacyConfigurators/StandardIncludes.php index 2f4a8812e41..cb5f72a1918 100644 --- a/src/Glpi/Config/LegacyConfigurators/StandardIncludes.php +++ b/src/Glpi/Config/LegacyConfigurators/StandardIncludes.php @@ -34,19 +34,11 @@ namespace Glpi\Config\LegacyConfigurators; -use Config; use Glpi\Application\View\TemplateRenderer; use Glpi\Config\ConfigProviderHasRequestTrait; use Glpi\Config\ConfigProviderWithRequestInterface; use Glpi\Config\LegacyConfigProviderInterface; use Glpi\Http\RequestPoliciesTrait; -use Glpi\System\Requirement\DatabaseTablesEngine; -use Glpi\System\RequirementsManager; -use Glpi\Toolbox\VersionParser; -use Html; -use Session; -use Toolbox; -use Update; final class StandardIncludes implements LegacyConfigProviderInterface, ConfigProviderWithRequestInterface { diff --git a/src/Glpi/Controller/NeedsUpdateController.php b/src/Glpi/Controller/NeedsUpdateController.php new file mode 100644 index 00000000000..8cf4a01653f --- /dev/null +++ b/src/Glpi/Controller/NeedsUpdateController.php @@ -0,0 +1,129 @@ +. + * + * --------------------------------------------------------------------- + */ + +namespace Glpi\Controller; + +use Config; +use DBmysql; +use Glpi\Application\View\TemplateRenderer; +use Glpi\System\Requirement\DatabaseTablesEngine; +use Glpi\System\RequirementsManager; +use Glpi\Toolbox\VersionParser; +use Html; +use Session; +use Symfony\Component\HttpFoundation\Response; +use Symfony\Component\HttpFoundation\StreamedResponse; +use Toolbox; + +class NeedsUpdateController extends AbstractController +{ + public function __invoke(string $key): Response + { + return new StreamedResponse($this->display(...)); + } + + public function display(): void + { + // Prevent debug bar to be displayed when an admin user was connected with debug mode when codebase was updated. + $debug_mode = $_SESSION['glpi_use_mode']; + Toolbox::setDebugMode(Session::NORMAL_MODE); + + /** @var DBmysql $DB */ + global $DB; + + /** @var array $CFG_GLPI */ + global $CFG_GLPI; + + $requirements = (new RequirementsManager())->getCoreRequirementList($DB); + $requirements->add(new DatabaseTablesEngine($DB)); + + $twig_params = [ + 'core_requirements' => $requirements, + 'try_again' => __('Try again'), + 'update_needed' => __('The GLPI codebase has been updated. The update of the GLPI database is necessary.'), + 'upgrade' => _sx('button', 'Upgrade'), + 'outdated_files' => __('You are trying to use GLPI with outdated files compared to the version of the database. Please install the correct GLPI files corresponding to the version of your database.'), + 'stable_release' => VersionParser::isStableRelease(GLPI_VERSION), + 'agree_unstable' => Config::agreeUnstableMessage(VersionParser::isDevVersion(GLPI_VERSION)), + 'outdated' => version_compare( + VersionParser::getNormalizedVersion($CFG_GLPI['version'] ?? '0.0.0-dev'), + VersionParser::getNormalizedVersion(GLPI_VERSION), + '>' + ) + ]; + + Html::nullHeader(__('Update needed')); + // language=Twig + echo TemplateRenderer::getInstance()->renderFromStringTemplate(<< +
+
+
+ {% include 'install/blocks/requirements_table.html.twig' with {'requirements': core_requirements} %} + {% if core_requirements.hasMissingMandatoryRequirements() or core_requirements.hasMissingOptionalRequirements() %} +
+ +
+ {% endif %} + {% if not core_requirements.hasMissingMandatoryRequirements() %} + {% if not outdated %} +
+ + {% if not stable_release %} + {{ agree_unstable|raw }} + {% endif %} +

+ {{ update_needed }} +

+ +
+ {% else %} +

+ {{ outdated_files }} +

+ {% endif %} + {% endif %} +
+
+
+ +TWIG, $twig_params); + Html::nullFooter(); + $_SESSION['glpi_use_mode'] = $debug_mode; + } +} diff --git a/src/Glpi/Http/Listener/CheckIfUpdateNeededListener.php b/src/Glpi/Http/Listener/CheckIfUpdateNeededListener.php new file mode 100644 index 00000000000..2ab6de2a781 --- /dev/null +++ b/src/Glpi/Http/Listener/CheckIfUpdateNeededListener.php @@ -0,0 +1,74 @@ +. + * + * --------------------------------------------------------------------- + */ + +namespace Glpi\Http\Listener; + +use Glpi\Controller\NeedsUpdateController; +use Glpi\Http\RequestPoliciesTrait; +use Glpi\Kernel\ListenersPriority; +use Symfony\Component\EventDispatcher\EventSubscriberInterface; +use Symfony\Component\HttpKernel\Event\RequestEvent; +use Symfony\Component\HttpKernel\KernelEvents; +use Update; + +final readonly class CheckIfUpdateNeededListener implements EventSubscriberInterface +{ + use RequestPoliciesTrait; + + public static function getSubscribedEvents(): array + { + return [ + KernelEvents::REQUEST => [ + ['onKernelRequest', ListenersPriority::REQUEST_LISTENERS_PRIORITIES[self::class]], + ], + ]; + } + + public function onKernelRequest(RequestEvent $event): void + { + if (!$event->isMainRequest()) { + return; + } + + if ( + \defined('SKIP_UPDATES') + || Update::isDbUpToDate() + || !$this->shouldCheckDbStatus($event->getRequest()) + ) { + return; + } + + $event->getRequest()->attributes->set('_controller', NeedsUpdateController::class); + } +} diff --git a/src/Glpi/Kernel/ListenersPriority.php b/src/Glpi/Kernel/ListenersPriority.php index 58c41304d36..489df393991 100644 --- a/src/Glpi/Kernel/ListenersPriority.php +++ b/src/Glpi/Kernel/ListenersPriority.php @@ -66,6 +66,10 @@ final class ListenersPriority // It must be executed before executing any controller (except controllers related to front-end assets). HttpListener\CheckDatabaseStatusListener::class => 450, + // This listener will ensure that GLPI is not being updated, or does not need a database update. + // Must also be executed before other controllers, since it defines its own controller. + HttpListener\CheckIfUpdateNeededListener::class => 440, + HttpListener\CheckMaintenanceListener::class => 425, // Legacy config providers. From 2089af7f22eb5508aac665503151488981941b7b Mon Sep 17 00:00:00 2001 From: Alex Rock Ancelet Date: Fri, 20 Dec 2024 14:57:39 +0100 Subject: [PATCH 2/2] =?UTF-8?q?Remove=20now=20unused=20StandardIncludes=20?= =?UTF-8?q?file=20=F0=9F=8E=89?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../legacyConfigProviders.php | 1 - .../LegacyConfigurators/StandardIncludes.php | 127 ------------------ 2 files changed, 128 deletions(-) delete mode 100644 src/Glpi/Config/LegacyConfigurators/StandardIncludes.php diff --git a/dependency_injection/legacyConfigProviders.php b/dependency_injection/legacyConfigProviders.php index f3156877b45..8d31e1764f9 100644 --- a/dependency_injection/legacyConfigProviders.php +++ b/dependency_injection/legacyConfigProviders.php @@ -55,7 +55,6 @@ * ⚠ Here, ORDER of definition matters! */ - $services->set(LegacyConfigurators\StandardIncludes::class)->tag($tagName, ['priority' => 160]); $services->set(LegacyConfigurators\CleanPHPSelfParam::class)->tag($tagName, ['priority' => 150]); $services->set(LegacyConfigurators\SessionConfig::class)->tag($tagName, ['priority' => 130]); diff --git a/src/Glpi/Config/LegacyConfigurators/StandardIncludes.php b/src/Glpi/Config/LegacyConfigurators/StandardIncludes.php deleted file mode 100644 index cb5f72a1918..00000000000 --- a/src/Glpi/Config/LegacyConfigurators/StandardIncludes.php +++ /dev/null @@ -1,127 +0,0 @@ -. - * - * --------------------------------------------------------------------- - */ - -namespace Glpi\Config\LegacyConfigurators; - -use Glpi\Application\View\TemplateRenderer; -use Glpi\Config\ConfigProviderHasRequestTrait; -use Glpi\Config\ConfigProviderWithRequestInterface; -use Glpi\Config\LegacyConfigProviderInterface; -use Glpi\Http\RequestPoliciesTrait; - -final class StandardIncludes implements LegacyConfigProviderInterface, ConfigProviderWithRequestInterface -{ - use ConfigProviderHasRequestTrait; - use RequestPoliciesTrait; - - public function execute(): void - { - /** - * @var array $CFG_GLPI - */ - global $CFG_GLPI; - - // Check version - if ($this->shouldCheckDbStatus($this->getRequest()) && !defined('SKIP_UPDATES') && !Update::isDbUpToDate()) { - // Prevent debug bar to be displayed when an admin user was connected with debug mode when codebase was updated. - $debug_mode = $_SESSION['glpi_use_mode']; - Toolbox::setDebugMode(Session::NORMAL_MODE); - - /** @var \DBmysql $DB */ - global $DB; - - $requirements = (new RequirementsManager())->getCoreRequirementList($DB); - $requirements->add(new DatabaseTablesEngine($DB)); - - $twig_params = [ - 'core_requirements' => $requirements, - 'try_again' => __('Try again'), - 'update_needed' => __('The GLPI codebase has been updated. The update of the GLPI database is necessary.'), - 'upgrade' => _sx('button', 'Upgrade'), - 'outdated_files' => __('You are trying to use GLPI with outdated files compared to the version of the database. Please install the correct GLPI files corresponding to the version of your database.'), - 'stable_release' => VersionParser::isStableRelease(GLPI_VERSION), - 'agree_unstable' => Config::agreeUnstableMessage(VersionParser::isDevVersion(GLPI_VERSION)), - 'outdated' => version_compare( - VersionParser::getNormalizedVersion($CFG_GLPI['version'] ?? '0.0.0-dev'), - VersionParser::getNormalizedVersion(GLPI_VERSION), - '>' - ) - ]; - - Html::nullHeader(__('Update needed'), $CFG_GLPI["root_doc"]); - // language=Twig - echo TemplateRenderer::getInstance()->renderFromStringTemplate(<< -
-
-
- {% include 'install/blocks/requirements_table.html.twig' with {'requirements': core_requirements} %} - {% if core_requirements.hasMissingMandatoryRequirements() or core_requirements.hasMissingOptionalRequirements() %} -
- -
- {% endif %} - {% if not core_requirements.hasMissingMandatoryRequirements() %} - {% if not outdated %} -
- - {% if not stable_release %} - {{ agree_unstable|raw }} - {% endif %} -

- {{ update_needed }} -

- -
- {% else %} -

- {{ outdated_files }} -

- {% endif %} - {% endif %} -
-
-
- -TWIG, $twig_params); - Html::nullFooter(); - $_SESSION['glpi_use_mode'] = $debug_mode; - exit(); - } - } -}