Download the PHP package laragear/expire-route without Composer
On this page you can find all versions of the php package laragear/expire-route. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download laragear/expire-route
More information about laragear/expire-route
Files in laragear/expire-route
Package expire-route
Short Description Don't find route models created after a moment in time.
License MIT
Informations about the package expire-route
Expire Route
Never found models or objects past their expiration time.
Become a sponsor
Your support allows me to keep this package free, up-to-date and maintainable. Alternatively, you can spread the word!
Requirements
- Laravel 11 or later
Installation
Just fire up Composer and require the package in your application
Usage
While Laravel Temporarily Protected Routes works great for making routes available for a given amount of time, this library uses your Eloquent Model in the route to expire it through a middleware.
To better understand how the middleware works, let's imagine we have the App\Models\Payment
model with an expires_at
attribute that determines when the payment should be become invalid. The expires
middleware does this automatically: if the expires_at
time is past, the request will be aborted with a HTTP 410 Gone
code.
Multiple route parameters
By default, the middleware will always check for the last route parameter in a route. You may set the name of the parameter if you require to check its expiration time.
Custom attribute
If your model doesn't have an expires_at
attribute to check, you can use dot.notation
to traverse the object attributes and find the expiration time.
Relative expiration
When you have a model that doesn't have an expiration time, you can set a time in minutes (or a string to be parsed by strtotime()
) to calculate from the created_at
attribute when the route should expire.
For example, by setting 60
, the route will expire once 60 minutes have passed since the creation of the App\Models\Payment
model.
If you want to calculate the time from other attribute than created_at
, issue the name of the attribute using dot.notation
.
[!WARNING]
If the property or attribute doesn't exist or returns
null
, it will be assumed the model has not expired yet.
Using the routeExpiresAt()
method
If the model or object implements the Laragear\ExpireRoute\Contracts\RouteExpirable
contract, the routeExpiresAt()
method will be used to retrieve the moment the route it should expire.
[!IMPORTANT]
Using the contract takes precedence, unless an attribute is specified by the middleware declaration itself.
Non Eloquent Models
Both middlewares are not limited to only Eloquent Models. It can be any object (even an array) that has a UNIX Epoch timestamp or a datetime, since the check is done by retrieving the value through data_get()
and then parsed by Laravel's Date Factory.
Fluent middleware declaration
You may also use the Laragear\ExpireRoute\Http\Middleware\Expires
middleware to fluently configure it in your route. It's a great way to set relative time expressively.
Laravel Octane compatibility
- There are no singletons using a stale application instance.
- There are no singletons using a stale config instance.
- There are no singletons using a stale request instance.
- There are no static properties written during a request.
There should be no problems using this package with Laravel Octane.
Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
License
This specific package version is licensed under the terms of the MIT License, at time of publishing.
Laravel is a Trademark of Taylor Otwell. Copyright © 2011-2025 Laravel LLC.
All versions of expire-route with dependencies
illuminate/support Version 11.*|12.*
illuminate/http Version 11.*|12.*
illuminate/routing Version 11.*|12.*