- Documentation >
- Guide >
- Content rendering >
- URLs and routes
URLs and routes
To link to a Location or Content item, use the ez_path()
Twig function.
You need to provide the function with a Location, Content, ContentInfo or RouteReference object:
| <p><a href="{{ ez_path(location) }}">Location</a></p>
<p><a href="{{ ez_path(content.contentInfo) }}">Content Info</a></p>
|
Use ez_url()
to get an absolute URL to a Content item or Location:
| <p><a href="{{ ez_url(location) }}">Location</a></p>
|
RouteReference
You can use the ez_route()
Twig function
to create a RouteReference object based on the provided information.
A RouteReference contains a route with its parameters and can be modified after it is created.
Here, the route is based on the ID of the Location.
| {% set routeReference = ez_route("ez_urlalias", { 'locationId': 2 }) %}
<p><a href="{{ ez_path(routeReference) }}">Route</a></p>
|
A route can also be based on the ID of the Content item.
The resulting link points to the Content item's main Location.
| {% set routeReference = ez_route("ez_urlalias", { 'contentId': 456 }) %}
<p><a href="{{ ez_path(routeReference) }}">Route</a></p>
|
With ez_route()
you can modify the route contained in RouteReference after creation, for example, by providing additional parameters:
| {% set routeReference = ez_route("ez_urlalias", { 'locationId': 2 }) %}
{% do routeReference.set("param", "param-value") %}
|
You can also use ez_route()
to create links to predefined routes, such as the ezplatform.search
route that leads to a search form page:
| <a href="{{ ez_path(ez_route('ezplatform.search')) }}">Search</a>
|
File download links
To provide a download link for a file, use ez_route()
with the ez_content_download
route:
| {% set download_route = ez_route('ez_content_download', {
'content': file,
'fieldIdentifier': 'file',
}) %}
<a href="{{ ez_path(download_route) }}">Download</a>
|
Route list
The following built-in routes are available for the front of the website.
Tip
To view all routes existing in the system, including internal and Back-Office related ones, run:
| php bin/console debug:router
|
Registration
Route name |
Path |
Description |
ezplatform.user.user_register |
/user/register |
User registration form |
ezplatform.user.register_confirmation ezplatform.user.user_register_confirmation |
/register-confirm /user/register-confirm |
Confirmation page after user registration |
Login
Route name |
Path |
Description |
login |
/login |
Login form |
logout silversolutionsCustomerLogout |
/logout /profile/logout |
Logging out the current user |
Profile
Route name |
Path |
Description |
silversolutionsCustomerDetail |
/profile |
User profile |
silversolutions_address_book_list |
/profile/address_book |
User address book |
Password
Route name |
Path |
Description |
ezplatform.user_profile.change_password silversolutions_password_change |
/user/change-password /change_password |
Form for password change |
ezplatform.user.forgot_password |
/user/forgot-password |
Form for password resetting |
ezplatform.user.forgot_password.migration |
/user/forgot-password/migration |
Form for resetting password after expiration |
ezplatform.user.forgot_password.login |
/user/forgot-password/login |
Form for resetting password based on login instead of email address |
ezplatform.user.reset_password |
/user/reset-password/{hashKey} |
Form for resetting password based on a generated link |
Shop
Content
Route name |
Path |
Description |
ez_content_download |
/content/download/{contentId}/{fieldIdentifier}/{filename} |
Downloading a binary file |
ezplatform.content.create_no_draft |
/content/create/nodraft/{contentTypeIdentifier}/{language}/{parentLocationId} |
Creating a Content item without using a draft |
ezplatform.content.draft.edit |
/content/edit/draft/{contentId}/{versionNo}/{language}/{locationId} |
Editing a Content item |
ezplatform.content.draft.create |
/content/create/draft/{contentId}/{fromVersionNo}/{fromLanguage} |
Creating a new draft |
Search
Route name |
Path |
Description |
ezplatform.search |
/search |
Search form |