Static routes
Static routes provide a way to create seemingly static content on a per site
base. Take the following example: In a multi-site installation you want to have
different robots.
files for each site that should be reachable at
/robots.
on each site. Now, you can add a static route robots.
to your site configuration and define which content should be delivered.
Routes can be configured as top level files (as in the robots.
case),
but may also be configured to deeper route paths
(my/
, for example). Matching is done on the
full path, but without any parameters.
Static routes can be configured via the user interface or directly in the YAML configuration. There are two options: deliver static text or resolve a TYPO3 URL.
Note
Static route resolving is implemented as a PSR-15 middleware. If the route path requested matches any one of the configured site routes, a response is directly generated and returned. This way there is minimal bootstrap code to be executed on a static route resolving request, mainly the site configuration needs to be loaded. Static routes cannot get parameters, as the matching is done solely on the path level.
staticText
The static
option allows to deliver simple text content. The text
can be added through a text field directly in the site configuration. This is
suitable for files like robots.
or humans.
.
A configuration example:
Static routes to assets
New in version 13.3
The type assets
allows to expose
resources which are typically located in the directory
EXT:
.
A configuration example:
- route: example.svg
type: asset
asset: 'EXT:backend/Resources/Public/Icons/Extension.svg'
- route: favicon.ico
type: asset
asset: 'EXT:my-sitepackage/Resources/Public/Icons/favicon.ico'
This enables you to reach the files at https://
and https://
.
The asset URL is configured on a per-site basis. This allows to deliver site-dependent custom favicon or manifest assets, for example.
TYPO3 URL (t3://)
The type uri
for a TYPO3 URL provides the option to render either a
file, page or URL. Internally, a request to the file or URL is done and its
content delivered.
A configuration example: