reelworx/t3-fakefrontend

A library for TYPO3 extensions to initialize a 'fake frontend' environment. Mainly for CLI/BE purposes.

Installs: 7 018

Dependents: 1

Suggesters: 0

Security: 0

Stars: 1

Forks: 1

Type:typo3-cms-extension

v3.1.0 2024-11-07 15:32 UTC

This package is auto-updated.

Last update: 2025-01-07 15:10:41 UTC


README

This library for TYPO3 extensions provides a utility to bootstrap a fake frontend environment (TSFE and other things) to be used when doing frontend related stuff from within other contexts like the backend or CLI.

When to use this library?

This library comes in handy if you need to generate absolute frontend links for site from within non-frontend context.

Examples:

  • If you generate mails from within a scheduler task, which should include links to frontend. You can the usual Fluid viewhelpers, once the "fake frontend" is established.
  • If you generate frontend links in a backend module.

Usage

// quickest usage
$fakeFrontend = new \FakeFrontendService();
$fakeFrontend->executeInFEContext($pageUid, function () {
    // do some work
});
// *If you need to do some more stuff manually, here is the longer version:*

// Note: This populates the globals TSFE, TYPO3_REQUEST and $_SERVER['HTTP_HOST']
// It is advisable to reset/unset those again, when not needed anymore.
// Especially in BE context this can cause unexpected side effects.

// create a fully initialized TSFE for given page uid
$fakeFrontend = new \FakeFrontendService();
$valid = $fakeFrontend->buildFakeFE($pageUid);
if ($valid) {
    //
    // ... do the work
    //
    $fakeFrontend->resetGlobals();
} else {
    // resetGlobals() is done internally already
    throw new \RuntimeException('Building fake FE failed', 0, $fakeFrontend->lastError);
}

A specific $GLOBALS['TSFE']->absRefPrefix can be enforced by configuring config.cliDomain in the template of the page. The value auto means to use GeneralUtility::getIndpEnv('TYPO3_SITE_PATH') as absRefPrefix.