jorisnoo / craft-locale-redirect
Browser locale detection and redirect for Craft CMS
Requires
- php: ^8.2
- craftcms/cms: ^5.0
Requires (Dev)
- pestphp/pest: ^3.8
- phpunit/phpunit: ^11.0
This package is auto-updated.
Last update: 2026-04-04 14:41:07 UTC
README
A Craft CMS module that automatically redirects visitors from / to their locale-specific home route based on their browser language preferences.
Features
- Detects the visitor's preferred language from the
Accept-Languageheader - Matches it against your Craft multi-site locales
- Redirects from
/to the best-matching locale home URL (e.g./en,/fr,/de) - Preserves query parameters through the redirect
- Configurable locale exclusions and restrictions
- Zero configuration required for basic usage
Requirements
- PHP 8.2+
- Craft CMS 5
Installation
composer require jorisnoo/craft-locale-redirect
Then register the module in your config/app.php:
return [ 'modules' => [ 'locale-redirect' => \Noo\CraftLocaleRedirect\Module::class, ], 'bootstrap' => ['locale-redirect'], ];
How It Works
When a visitor hits your site's root URL (/), the module:
- Reads the
Accept-Languageheader from the browser - Fetches all configured Craft site locales and their URLs
- Finds the best match between browser preferences and available locales
- Issues a
302redirect to the matched locale's home URL
If no match is found, the visitor is redirected to the primary site's URL (or a configured fallback). Query parameters are preserved through the redirect.
Configuration
The module works out of the box with no configuration. To customize behavior, create a config/locale-redirect.php file in your Craft project:
<?php return [ 'excludeSites' => [], 'exclude' => [], 'only' => [], 'fallback' => null, ];
Exclude Sites
Prevent the redirect from triggering on specific sites (by handle). Useful when locale-specific sites already have their own prefix and shouldn't redirect further:
'excludeSites' => ['english', 'german'],
Exclude Locales
Prevent specific locales from being redirect targets:
'exclude' => ['de', 'it'],
Restrict to Specific Locales
Only allow redirection to specific locales. Takes precedence over exclude when both are set:
'only' => ['en', 'fr'],
Fallback URL
The URL to redirect to when no browser locale matches. Defaults to the primary site URL:
'fallback' => '/en',
Branching and Versioning
This package follows Semantic Versioning. Only Craft 5 is supported.
License
The MIT License (MIT). Please see LICENSE for more information.