jeffersongoncalves / laravel-locale-cookie
A Laravel middleware that resolves the application locale from a cookie, validating the requested value against a configurable list of supported locales and falling back to a sensible default when the cookie is missing or unknown. Cookie name, supported locales, and fallback locale are all driven by
Package info
github.com/jeffersongoncalves/laravel-locale-cookie
pkg:composer/jeffersongoncalves/laravel-locale-cookie
Fund package maintenance!
Requires
- php: ^8.2
- illuminate/support: ^11.0|^12.0|^13.0
- spatie/laravel-package-tools: ^1.14
Requires (Dev)
- larastan/larastan: ^3.0
- orchestra/testbench: ^9.0|^10.0|^11.0
- pestphp/pest: ^3.7.4|^4.0
- pestphp/pest-plugin-laravel: ^3.0|^4.0
README
Laravel Locale Cookie
A Laravel middleware that resolves the application locale from a cookie. The requested value is validated against a configurable list of supported locales and ignored when it is missing or unknown, falling back to a sensible default. Cookie name, supported locales, and fallback locale are all driven by config.
Installation
You can install the package via composer:
composer require jeffersongoncalves/laravel-locale-cookie
You can publish the config file with:
php artisan vendor:publish --tag="locale-cookie-config"
This is the contents of the published config file:
return [ 'cookie' => 'locale', 'supported' => ['en'], 'fallback' => null, ];
cookie— the name of the cookie the middleware reads the visitor's locale from (defaultlocale).supported— the whitelist of accepted locales. A cookie value that is not in this list is ignored.fallback— the locale applied when the cookie is missing or unsupported. Whennull, the middleware falls back to the framework'sconfig('app.fallback_locale').
Usage
Register the middleware on the route group that should be locale-aware. The middleware reads the cookie, validates it against your supported list, and applies the matching locale (or the fallback) for the rest of the request:
use JeffersonGoncalves\LocaleCookie\Middleware\SetLocale; Route::middleware(SetLocale::class)->group(function () { // ...locale-aware routes });
For convenience, the package also registers a locale middleware alias, so you can reference it by name:
Route::middleware('locale')->group(function () { // ...locale-aware routes });
You can also alias it in bootstrap/app.php:
->withMiddleware(function (Middleware $middleware) { $middleware->web(append: [ \JeffersonGoncalves\LocaleCookie\Middleware\SetLocale::class, ]); })
Setting the cookie
This package only reads the locale cookie — it never writes it. Your application is responsible for setting the cookie when the visitor chooses a locale. You can do that from PHP:
return redirect()->back()->withCookie(cookie()->forever('locale', 'pt_BR'));
…or from the client with JavaScript:
document.cookie = 'locale=pt_BR; path=/; max-age=31536000';
Encrypted cookies
By default Laravel's EncryptCookies middleware encrypts every cookie, and it runs before this middleware. To keep the read side (the SetLocale middleware, which reads the raw value via $request->cookies->get()) and the write side (the bundled switch route) consistent — and so that client-set cookies (e.g. the JavaScript example above, which are never encrypted) keep working — the package automatically registers the configured cookie name in EncryptCookies' exception list (via EncryptCookies::except()). The cookie is therefore always written and read as a plaintext value; you do not need to add it to $except yourself.
If you change locale-cookie.cookie, the exclusion follows the new name automatically.
Using with Livewire
If your locale-aware pages use Livewire, register the middleware as a Livewire persistent middleware as well, so subsequent /livewire/update requests keep the visitor's locale instead of falling back to the default. Register both the route-group middleware and the persistent middleware (pattern taken from the source project this package was extracted from):
use Livewire\Livewire; use JeffersonGoncalves\LocaleCookie\Middleware\SetLocale; // In a service provider's boot() method Livewire::addPersistentMiddleware([ SetLocale::class, ]);
Locale switch route
The package registers a ready-made route that persists the chosen locale in the cookie and redirects back to a same-host Referer (open-redirect safe). Point your language switcher at it:
@foreach (config('locale-cookie.supported') as $code) <a href="{{ route('locale.switch', ['locale' => $code]) }}">{{ strtoupper($code) }}</a> @endforeach
The {locale} param is constrained to config('locale-cookie.supported'). Configure (or disable) it under locale-cookie.switch:
'switch' => [ 'enabled' => true, 'path' => 'locale/{locale}', 'name' => 'locale.switch', 'lifetime' => 60 * 24 * 365, // cookie lifetime in minutes 'middleware' => ['web'], // attaches the queued cookie; the locale cookie is excluded from encryption ],
Shortening a locale code
The LocaleCookie::short() helper reduces a locale to its short language code — handy for <html lang="…">, flag icons, or any place you only need the base language:
use JeffersonGoncalves\LocaleCookie\LocaleCookie; LocaleCookie::short('pt_BR'); // 'pt' LocaleCookie::short('pt-BR'); // 'pt' LocaleCookie::short('EN'); // 'en' LocaleCookie::short(); // current app locale, shortened LocaleCookie::short(''); // 'en' (fallback when there is no usable prefix)
<html lang="{{ \JeffersonGoncalves\LocaleCookie\LocaleCookie::short() }}">
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.
