[BUGFIX] Show correct rendering times in admin panel
[Packages/TYPO3.CMS.git] / typo3 / sysext / frontend / Classes / Middleware / TimeTrackerInitialization.php
1 <?php
2 declare(strict_types = 1);
3 namespace TYPO3\CMS\Frontend\Middleware;
4
5 /*
6 * This file is part of the TYPO3 CMS project.
7 *
8 * It is free software; you can redistribute it and/or modify it under
9 * the terms of the GNU General Public License, either version 2
10 * of the License, or any later version.
11 *
12 * For the full copyright and license information, please read the
13 * LICENSE.txt file that was distributed with this source code.
14 *
15 * The TYPO3 project - inspiring people to share!
16 */
17
18 use Psr\Http\Message\ResponseInterface;
19 use Psr\Http\Message\ServerRequestInterface;
20 use Psr\Http\Server\MiddlewareInterface;
21 use Psr\Http\Server\RequestHandlerInterface;
22 use TYPO3\CMS\Core\TimeTracker\TimeTracker;
23 use TYPO3\CMS\Core\Utility\GeneralUtility;
24
25 /**
26 * Initializes the time tracker (singleton) for the whole TYPO3 Frontend
27 *
28 * @internal
29 */
30 class TimeTrackerInitialization implements MiddlewareInterface
31 {
32 /**
33 * Starting time tracking (by setting up a singleton object)
34 *
35 * @param ServerRequestInterface $request
36 * @param RequestHandlerInterface $handler
37 * @return ResponseInterface
38 */
39 public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
40 {
41 $configuredCookieName = trim($GLOBALS['TYPO3_CONF_VARS']['BE']['cookieName']) ?: 'be_typo_user';
42 $timeTracker = GeneralUtility::makeInstance(
43 TimeTracker::class,
44 $request->getCookieParams()[$configuredCookieName] ? true : false
45 );
46 $timeTracker->start();
47 $timeTracker->push('');
48
49 return $handler->handle($request);
50 }
51 }