Attention
TYPO3 v11 has reached end-of-life as of October 31th 2024 and is no longer being maintained. Use the version switcher on the top left of this page to select documentation for a supported version of TYPO3.
Need more time before upgrading? You can purchase Extended Long Term Support (ELTS) for TYPO3 v11 here: TYPO3 ELTS.
TSFE
What is TSFE?
TSFE is short for \TYPO3\
,
a class which exists in the system extension EXT:frontend.
As the name implies: A responsibility of TSFE is page rendering. It also handles reading from and writing to the page cache. For more details it is best to look into the source code.
There are several contexts in which the term TSFE is used:
- PHP: It is passed as request attribute frontend.controller
- PHP: It was and is available as global array
$GLOBALS
in PHP.['TSFE'] - TypoScript: TypoScript function TSFE which can be used to access public properties in TSFE.
The TypoScript part is covered in the TypoScript Reference: TSFE. In this section we focus on the PHP part and give an overview, in which way the TSFE class can be used.
Accessing TSFE
Attention
Some of the former public properties and methods have been changed to protected or marked as internal. Often, accessing TSFE is no longer necessary, and there are better alternatives.
Access $GLOBALS
directly only as a last resort,
usage is strongly discouraged, if not absolutely necessary.
From the source:
When calling a frontend page, an instance of this object is available as
$GLOBALS
, even though the Core development strives to get rid of this in the future.['TSFE']
If access to the
\TYPO3\
instance is
necessary, use the request attribute
frontend.controller:
$frontendController = $request->getAttribute('frontend.controller');
See also
TSFE is not available in all contexts. In particular, it is only available in frontend contexts, not in the backend or CLI.
Initializing $GLOBALS
in the backend is sometimes done in code
examples found online. This is not recommended. TSFE is not initialized in the
backend context by the Core (and there is usually no need to do this).
From the PHP documentation:
As of PHP 8.1.0, $GLOBALS is now a read-only copy of the global symbol table. That is, global variables cannot be modified via its copy.
https://www.php.net/manual/en/reserved.variables.globals.php
Howtos
Following are some examples which use TSFE and alternatives to using TSFE, where available:
Access ContentObjectRenderer
Access the \TYPO3\
(often referred to as "cObj"):
// !!! discouraged
$cObj = $GLOBALS['TSFE']->cObj;
Obtain TSFE from request attribute 'frontend.controller':
$frontendController = $request->getAttribute('frontend.controller');
$cObj = $frontendController->cObj;
In the case of user function (for example, a non-Extbase plugin) via setter injection:
public function setContentObjectRenderer(ContentObjectRenderer $cObj): void
{
$this->cObj = $cObj;
}
Access current page ID
Access the current page ID:
// !!! discouraged
$pageId = $GLOBALS['TSFE']->id;
Can be done using the 'routing' request attribute:
$pageArguments = $request->getAttribute('routing');
$pageId = $pageArguments->getPageId();
Access frontend user information
// !!! discouraged
$feUser = $GLOBALS['TSFE']->fe_user;
Use the frontend.user:
/** @var \TYPO3\CMS\Frontend\Authentication\FrontendUserAuthentication $frontendUser */
$frontendUser = $request->getAttribute('frontend.user');
Some information via frontend and backend users con be obtained via the user aspect. For example:
// return whether a frontend user is logged in
$context->getPropertyFromAspect('frontend.user', 'isLoggedIn');
Get current base URL
It used to be possible to get the base URL configuration (from TypoScript
config.
) with the TSFE
base
property. The
property is now protected and deprecated since TYPO3 v12. Already in
earlier version, site configuration should be used to get the base URL
of the current site.
// !!! deprecated
$GLOBALS['TSFE']->baseURL
/** @var \TYPO3\CMS\Core\Site\Entity\Site $site */
$site = $request->getAttribute('site');
// array
$siteConfiguration = $site->getConfiguration();
$baseUrl = $siteConfiguration['base'];