Sitemap Plugin for Sylius eCommerce platform
Goes out to the Sylius team. The core code of this plugin is created by the Sylius team.
Unfortunately it got removed from the Sylius core. Luckily the Sylius team approved the
extraction to a separate bundle.
composer require stefandoorn/sitemap-plugin
.app/config/bundles.php
:
SitemapPlugin\SitemapPlugin::class => ['all' => true],
app/config/packages/_sylius.yaml
:
- { resource: "@SitemapPlugin/Resources/config/config.yaml" }
app/config/routes.yaml
:
sylius_sitemap:
resource: "@SitemapPlugin/Resources/config/routing.yml"
Add to app/config/packages/sylius_sitemap.yaml
:
Forcing HTTPS on Generated URLs, see Symfony Docu. In console commands, where there is no HTTP request, URLs use http by default. You can change this globally with these configuration parameters:
# config/services.yaml
parameters:
router.request_context.scheme: 'https'
Generate your sitemap from the CLI:
$ bin/console sylius:sitemap:generate
Add this command to your cronjob to regularly generate a new sitemap, e.g. once a day.
If you only want to generate the sitemap for a specific channel, use:
$ bin/console sylius:sitemap:generate --channel=US_WEB
The plugin defines three default URI’s:
sitemap.xml
: redirects to sitemap_index.xml
sitemap_index.xml
: renders the sitemap index file (with links to the provider xml files)Next to this, each provider registers its own URI. Take a look in the sitemap index file for the correct URI’s.
Get a full list of configuration: bin/console config:dump-reference sitemap
sitemap:
providers:
products: true
taxons: true
static: true
template: '@SitemapPlugin/show.xml.twig'
index_template: '@SitemapPlugin/index.xml.twig'
exclude_taxon_root: true
hreflang: true
images: true
static_routes:
- { route: sylius_shop_homepage, parameters: [], locales: [] }
- { route: sylius_shop_contact_request, parameters: [], locales: [] }
The request context is also important for generating the URLs inside the sitemap:
localhost
By default, the sitemaps will be saved in %kernel.root_dir%/var/sitemap
. You can change this setting
by adjusting the parameter sylius.sitemap.path
.
providers
: Enable/disable certain providers to be included in the sitemap. Defaults are true.exclude_taxon_root
: Often you don’t want to include the root of your taxon tree as it has a generic name as ‘products’.hreflang
: Whether to generate alternative URL versions for each locale. Defaults to true. Background: https://support.google.com/webmasters/answer/189077?hl=en.images
: Whether to add images to URL output in case the provider adds them. Defaults to true. Background: https://support.google.com/webmasters/answer/178636?hl=en.sylius.sitemap_provider
UrlProviderInterface