Dynamic Cache, Database, and Mail Builders in Laravel 11.31
Last updated on by Paul Redmond
The Laravel team released v11.31, which includes dynamic cache/db/mail builders, a cache token repository, a URL::forceHttps()
convenience method, and more.
Cache Token Repository
Andrew Brown contributed a cache token repository as an alternative way to store password reset tokens:
This PR proposes a new CacheTokenRepository which will allow the password reset tokens to be handled via cache. IMO cache is a perfect storage medium because it can be more ephemeral, just like the password reset tokens.
To enable this new CacheTokenRepository, adjust your config/auth.php like so:
'passwords' => [ //new cache driver 'customers' => [ 'driver' => 'cache', 'store' => 'passwords', 'provider' => 'customers', 'expire' => 60, 'throttle' => 60, ], //default old database driver 'users' => [ 'provider' => 'users', 'table' =>'password_reset_tokens', 'expire' => 60, 'throttle' => 60, ],],
See Pull Request #53428 for details on the implementation.
Dynamically Build Mailers On-Demand
Steve Bauman contributed the ability to dynamically build a mailer and send it using the Mail::build()
method. This allows developers to create mailers based on a given configuration instead of being hard-coded in the config files:
use Illuminate\Support\Facades\Mail; $mailer = Mail::build([ 'transport' => 'smtp', 'host' => '127.0.0.1', 'port' => 587, 'encryption' => 'tls', 'username' => 'usr', 'password' => 'pwd', 'timeout' => 5,]); $mailer->send($mailable);
See Pull Request #53411 for discussion and implementation details.
Add DB::build() Method
Similar to the Mail::build()
method, Steve Bauman contributed DB::build()
to dynamically create new DB connections that are not defined in your configuration file:
use Illuminate\Support\Facades\DB; $sqlite = DB::build([ 'driver' => 'sqlite', 'database' => ':memory:',]); $mysql = DB::build([ 'driver' => 'mysql', 'database' => 'forge', 'username' => 'root', 'password' => 'secret',]); $pgsql = DB::build([ 'driver' => 'pgsql', // ...]); $sqlsrv = DB::build([ 'driver' => 'sqlsrv', // ...]);
See Pull Request #53464 for details.
Add Cache::build() to Create On-demand Cache Repositories
Steve Bauman contributed the ability to dynamically build Cache repositories on-demand using the Cache::build()
method. Similar to the DB and Mailer dynamic build method, you can create cache repositories not defined in your configuration file:
use Illuminate\Support\Facades\Cache; $apc = Cache::build([ 'driver' => 'apc',]); $array = Cache::build([ 'driver' => 'array', 'serialize' => false,]); $database = Cache::build([ 'driver' => 'database', 'table' => 'cache', 'connection' => null, 'lock_connection' => null,]); $file = Cache::build([ 'driver' => 'file', 'path' => storage_path('framework/cache/data'),]);
See Pull Request #53454 for implementation details.
onQueue()
Method Accepts Backed Enums
Batch and Chain Philip Iezzi contributed the ability to use a backed enumeration with the onQueue()
method of a Bus chain:
// BeforeBus::chain($jobs) ->onQueue(QueueName::long->value)->dispatch(); // AfterBus::chain($jobs) ->onQueue(QueueName::long)->dispatch();
See Pull Request #53359 for implementation details.
removeDeferredServices()
Method
Add Application Ollie Read contributed the removeDeferredServices()
application method to remove a deferred service from the application container.
// Before$deferredServices = $app->getDeferredServices(); unset($deferredServices['auth.password'], $deferredServices['auth.password.broker']); $app->setDeferredServices($deferredServices); // After$app->removeDeferredServices(['auth.password', 'auth.password.broker']);
This use-case isn't a common one that you'll need, but this method compliments to get and set methods of deferred services nicely. See Pull Request #53362 for details.
Ability to Append and Prepend Middleware Priority from the Application Builder
Ollie Read contributed another low-level change to append and prepend middleware priority to the application builder, allowing access to add middleware after/before methods on the kernel:
return Application::configure(basePath: dirname(__DIR__)) ->withRouting( web: __DIR__.'/../routes/web.php', commands: __DIR__.'/../routes/console.php', health: '/up', ) ->withMiddleware(function (Middleware $middleware) { $middleware->appendToPriorityList( [ \Illuminate\Cookie\Middleware\EncryptCookies::class, \Illuminate\Contracts\Auth\Middleware\AuthenticatesRequests::class, ], \Illuminate\Routing\Middleware\ValidateSignature::class ); $middleware->prependToPriorityList( [ \Illuminate\Cookie\Middleware\EncryptCookies::class, \Illuminate\Contracts\Auth\Middleware\AuthenticatesRequests::class, ], \Illuminate\Routing\Middleware\ValidateSignature::class ); }) ->withExceptions(function (Exceptions $exceptions) { // })->create();
See Pull Request #53326 for further details.
forceHttps()
Method to Enforce HTTPs Scheme for URLs
Add Dasun Tharanga contributed the forceHttps()
method, which simplifies enforcing HTTPs for URLs requiring such. The method accepts a boolean, making it easy to force HTTPs for a given set of environments:
URL::forceHttps( $this->app->isProduction()); URL::forceHttps( $this->app->environment('staging', 'production'));
See Pull Request #53381 for implementation details.
Release notes
You can see the complete list of new features and updates below and the diff between 11.30.0 and 11.31.0 on GitHub. The following release notes are directly from the changelog:
v11.31.0
- [11.x] Refactor: return Command::FAILURE by @fernandokbs in https://github.com/laravel/framework/pull/53354
- Allow the Batch and Chain onQueue method to accept Backed Enums by @onlime in https://github.com/laravel/framework/pull/53359
- Add transaction generics by @MatusBoa in https://github.com/laravel/framework/pull/53357
- Add laravel default exception blade files to view:cache by @SamuelWei in https://github.com/laravel/framework/pull/53353
- [11.x] Added
useCascadeTruncate
method forPostgresGrammar
by @korkoshko in https://github.com/laravel/framework/pull/53343 - Add Application::removeDeferredServices method by @ollieread in https://github.com/laravel/framework/pull/53362
- Add the ability to append and prepend middleware priority from the application builder by @ollieread in https://github.com/laravel/framework/pull/53326
- Fix typo in Translator code comment by @caendesilva in https://github.com/laravel/framework/pull/53366
- [11.x] Handle HtmlString constructed with a null by @sperelson in https://github.com/laravel/framework/pull/53367
- [11.x] Add
URL::forceHttps()
to enforce HTTPS scheme for URLs by @dasundev in https://github.com/laravel/framework/pull/53381 - [11.x] Refactor and add remaining test cases for the DatabaseUuidFailedJobProviderTest class by @kevinb1989 in https://github.com/laravel/framework/pull/53408
- [11.X] Postgres Aurora failover - DetectsLostConnections by @vifer in https://github.com/laravel/framework/pull/53404
-
whereFullText
case consistency by @parth391 in https://github.com/laravel/framework/pull/53395 - [11.x] Add
HasFactory
trait tomake:model
generation command using--all
options by @adel007gh in https://github.com/laravel/framework/pull/53391 - Introduce support for popping items from a stackable context item by @denjaland in https://github.com/laravel/framework/pull/53403
- [11.x] Test Improvements by @crynobone in https://github.com/laravel/framework/pull/53414
- [11.x] Add ability to dynamically build mailers on-demand using
Mail::build
by @stevebauman in https://github.com/laravel/framework/pull/53411 - [11.x] Refactor and add remaining test cases for the DatabaseFailedJobProviderTest class by @kevinb1989 in https://github.com/laravel/framework/pull/53409
- [11.x] Fix error event listener in Vite prefetching by @jnoordsij in https://github.com/laravel/framework/pull/53439
- [11.x] Ensure datetime cache durations account for script execution time by @timacdonald in https://github.com/laravel/framework/pull/53431
- [11.x] Fix fluent syntax for HasManyThrough when combining HasMany followed by HasOne by @jnoordsij in https://github.com/laravel/framework/pull/53335
- Correct parameter type of Collection::diffKeys() and Collection::diffKeysUsing() by @AJenbo in https://github.com/laravel/framework/pull/53441
- Correct parameter type of Collection::intersectByKeys() by @AJenbo in https://github.com/laravel/framework/pull/53444
- Fix schema foreign ID support for tables with non-standard primary key by @willrowe in https://github.com/laravel/framework/pull/53442
- [11.x] Cache token repository by @browner12 in https://github.com/laravel/framework/pull/53428
- Fix validation message when there is a parameter with escaped dot "." by @mdmahbubhelal in https://github.com/laravel/framework/pull/53416
- [11.x] add optional prefix for cache key by @browner12 in https://github.com/laravel/framework/pull/53448
- [11.x] Do not overwrite existing link header(s) in
AddLinkHeadersForPreloadedAssets
middleware by @jnoordsij in https://github.com/laravel/framework/pull/53463 - [11.x] use assertTrue and assertFalse method, instead of using assertE… by @iamyusuf in https://github.com/laravel/framework/pull/53453
- [11.x] Add
DB::build
method by @stevebauman in https://github.com/laravel/framework/pull/53464 - [11.x] Add ability to dynamically build cache repositories on-demand using
Cache::build
by @stevebauman in https://github.com/laravel/framework/pull/53454 - [11.x] Skip the number of connections transacting while testing to run callbacks by @tonysm in https://github.com/laravel/framework/pull/53377