A package for Laravel that can be used to filter a model's records.
Simply the package checks the request query for keys that match the corresponding filter keys set for the model then builds the query.
Each model has a corresponding filters
file where it's filters can be registered and mapped.
Each registered filter
is a unique file that contains the necessary functionality to build a query.
This means that for models that have a title
column, they can share the call the same filter file hence reducing code duplication.
Use composer to install the package:
composer require miracuthbert/laravel-eloquent-filters
The package takes advantage of Laravel Auto-Discovery, so it doesn't require you to manually add the ServiceProvider.
If you don't use auto-discovery, add the ServiceProvider to the providers array in config/app.php
Miracuthbert\Filters\EloquentFiltersServiceProvider::class
If you want to publish the config
file use the commands below in your console
php artisan vendor:publish --provider=Miracuthbert\Filters\EloquentFiltersServiceProvider --tag=filters-config
A filter for a model generally extends the Miracuthbert\Filters\FiltersAbstract
.
It contains a list of filters that will should be applied to a the model and a map of key/value
pair of filters list.
To create one:
First, create a model with php artisan make:model
command.
Then create a filter file for the model using:
php artisan filter:model {name}
// example
php artisan filter:make UserFilters
// within specific namespace
php artisan filter:make Users\\UserFilters
Switch name
with the model name and preferably add suffix Filters
to indicate it is a model filter, eg. UserFilters
Copy and add the block of code printed out in the console, to the related model. Do not forget to pull in the required namespaces.
After setup above in any controller that you call the model instance, call the filter
scope passing an instance of the `Illuminate\Http\Request'.
$users = User::filter($request)->get();
In case you have disabled appending of the filters query to a paginator, you could do it manually by using the filters_query
helper:
$users->appends(filters_query());
// in blade view
{{ $users->appends(filters_query())->links() }}
All created filters by default will be placed within, App\Filters
directory (namespace).
To create a filter use:
php artisan filter:make {name}
// example
php artisan filter:make NameFilter
// within specific namespace
php artisan filter:make Users\\NameFilter
Switch name
with the name of the filter, eg. NameFilter
(normal filter), CreatedOrder
(ordering filter)
When creating a filter, it is good to add
Filter
orOrder
to the name for ease of use.
You can then open the filter file and add your custom query functionality. See the filter:make
command options for some preset templates.
Filters are basically blocks of code that extend
Illuminate\Database\Eloquent\Builder
, so you are not limited to the preset templates.
You can pass, the following options to the filter:make
command, to make use of some of the common filter templates:
column
, Indicates the column the filter should be implemented onbool
, Indicates if generated filter should be a boolean filter classnull
, Indicates if generated filter should be a null check filter classorder
, Indicates if generated filter should be an order filter classrelation
, Generates a filter class for the given relationship
After creating a filter, to use it open a model filter and register a key/value
pair under the $filters
field.
/**
* A list of filters.
*
* @var array
*/
protected $filters = [
'name' => NameFilter::class,
'email' => EmailFilter::class,
'created' => CreatedOrder::class,
];
In a model filter, you can register a key/value
pair under the $defaultFilters
field, for filters you want to be applied by default.
key
should be the same as the one registered on the$filters
field,value
should be an actual database value.
Note: Default filters should only be used for filters with fixed
or unchanging
values, eg. true
, false
/**
* A list of default filters.
*
* @var array
*/
protected $defaultFilters = [
'created' => 'desc',
];
You can override default filters in the constructor of a model filter, by adding different checks.
// constructor
if ($request->hasAny('cancelled', 'completed')) {
$this->defaultFilters = [
'upcoming' => 'false'
];
}
There available commands within the package:
filter:model
: Create a new filter class for a modelfilter:make
: Creates a new Eloquent filter class
Pass
--help
option to the commands to get more details on using them
If you discover a security vulnerability, please send an e-mail to Cuthbert Mirambo via miracuthbert@gmail.com. All security vulnerabilities will be promptly addressed.
The project is open-sourced software licensed under the MIT license.