Project

General

Profile

Actions

Epic #103035

open

Handle EXT syntax more flexible

Added by Benni Mack 10 months ago. Updated about 1 month ago.

Status:
New
Priority:
Should have
Assignee:
-
Category:
System/Bootstrap/Configuration
Start date:
2024-02-04
Due date:
% Done:

0%

Estimated time:
(Total: 0.00 h)
Sprint Focus:

Description

Currently, TYPO3 comes with a logic to put all in an extension which can be referenced via "EXT:", this goes for language files, public assets, private templates, configuration files. PHP is usually done via autoloading, so this is not considered here anymore.

However, TYPO3 bases most of the logic on a few super-god methods:
  • GeneralUtility::getAbsFileName()
  • PathUtility::getAbsoluteWebPath() in order to get the path to a public file

And then, it deals with public assets such as images in a bad way, when it comes to image processing.

This is bad architecture design and part of our legacy.

What we're lacking is:
  • A flexible way to reference the files, and read / write through them than to deal with absolute or relative paths to files
  • A better way to deal with public assets from extensions in FAL, VHs, TypoScript
  • A better way to reference translation labels instead of hard-coded paths (Resources/Private/Language) and template paths

In an ideal world, these paths can be overridden by the local project, instead of setting up a path repository, a site extension and replicate the base structure, just in order to change a template.

Ideally, the package manager allows to fetch files from packages by utilizing a PackageFileResolver, so e.g. paths inside the package do not matter anymore. Instead, they could be changed to whatever location ext authors like. We could introduce a typo3.json file, and finally get rid of ext_emconf.php. typo3.json could be optional, but contains the paths / locations to the files. Actually, in composer mode projects, the root project is already the "root" extension, but it would feel awkward to reference files like "EXT:root" right?

Files should be modelled a "PackageFile" object instead of a string, and can build a URI with "getUri($request): Uri" if they are allowed to be accessed from the outside.


Subtasks 1 (1 open0 closed)

Feature #103036: Customize TYPO3 without a site extensionNew2024-02-04

Actions
Actions

Also available in: Atom PDF